

521, 054

Rec'd PCT/PTO 12 JAN 2005

(12)特許協力条約に基づいて公開された国際出願

(19) 世界知的所有権機関  
国際事務局(43) 国際公開日  
2004年11月25日 (25.11.2004)

PCT

(10) 国際公開番号  
WO 2004/102811 A1

(51) 国際特許分類:

H03M 13/09, 13/19

(21) 国際出願番号:

PCT/JP2004/005562

(22) 国際出願日:

2004年4月19日 (19.04.2004)

(25) 国際出願の言語:

日本語

(26) 国際公開の言語:

日本語

(30) 優先権データ:

特願2003-133941 2003年5月13日 (13.05.2003) JP  
特願2003-294383 2003年8月18日 (18.08.2003) JP(71) 出願人(米国を除く全ての指定国について): ソニー  
株式会社 (SONY CORPORATION) [JP/JP]; 〒1410001  
東京都品川区北品川6丁目7番35号 Tokyo (JP).

(72) 発明者; および

(75) 発明者/出願人(米国についてのみ): 横川 峰志  
(YOKOKAWA, Takashi) [JP/JP]; 〒1410001 東京都品  
川区北品川6丁目7番35号 ソニー株式会社内  
Tokyo (JP). 宮内 俊之 (MIYAUCHI, Toshiyuki) [JP/JP];  
〒1410001 東京都品川区北品川6丁目7番35号  
ソニー株式会社内 Tokyo (JP). 飯田 康博 (MIDA,  
Yasuhiro) [JP/JP]; 〒1410001 東京都品川区北品川  
6丁目7番35号 ソニー株式会社内 Tokyo (JP).(74) 代理人: 稲本 義雄 (INAMOTO, Yoshio); 〒1600023 東  
京都新宿区西新宿7丁目11番18号 711ビル  
ディング4階 Tokyo (JP).(81) 指定国(表示のない限り、全ての種類の国内保護が  
可能): AE, AG, AL, AM, AT, AU, AZ, BA, BB, BG, BR,

[続葉有]

(54) Title: DECODING DEVICE, DECODING METHOD, AND PROGRAM

(54) 発明の名称: 復号装置および復号方法、並びにプログラム



321...CONTROL SECTION  
 314...CYCLIC SHIFT CIRCUIT  
 A...MEMORY FOR RECEPTION DATA  
 318...RECEPTION LLR  
 320...CYCLIC SHIFT CIRCUIT

WO 2004/102811 A1

(57) Abstract: There are provided a decoding device, a decoding method, and a program for realizing decoding of the LDPC code capable of suppressing the circuit size, suppressing the operation frequency to a sufficiently realizable range, and easily controlling memory access. The inspection matrix of the LDPC code is composed of a combination of a unit matrix  $p \times p$ , the unit matrix in which one or more 1 have become 0, their cyclic shifts, a sum of them, and a 0 matrix of  $p \times p$ . A check node calculation section (313) simultaneously performs P check node calculations while a variable node calculation section (319) simultaneously performs P variable node calculations.

(57) 要約: 本発明は、回路規模を抑制しつつ、動作周波数も十分実現可能な範囲に抑え、メモリアクセスの制御も容易に行うことができるLDPC符号の復号を実現する復号装置および復号方法、並びにプログラムに関する。LDPC符号の検査行列は、 $P \times P$ の単位行列、その単位行列の1のうちの1個から数個が0になった行列、それらのサイクリックシフト、それ

[続葉有]



BW, BY, BZ, CA, CH, CN, CO, CR, CU, CZ, DE, DK, DM,  
DZ, EC, EE, EG, ES, FI, GB, GD, GE, GH, GM, HR, HU,  
ID, IL, IN, IS, KE, KG, KP, KR, KZ, LC, LK, LR, LS, LT,  
LU, LV, MA, MD, MG, MK, MN, MW, MX, MZ, NA, NI,  
NO, NZ, OM, PG, PH, PL, PT, RO, RU, SC, SD, SE, SG,  
SK, SL, SY, TJ, TM, TN, TR, TT, TZ, UA, UG, US, UZ,  
VC, VN, YU, ZA, ZM, ZW.

KZ, MD, RU, TJ, TM), ヨーロッパ(AT, BE, BG, CH, CY,  
CZ, DE, DK, EE, ES, FI, FR, GB, GR, HU, IE, IT, LU, MC,  
NL, PL, PT, RO, SE, SI, SK, TR), OAPI(BF, BJ, CF, CG,  
CI, CM, GA, GN, GQ, GW, ML, MR, NE, SN, TD, TG).

添付公開書類:  
— 國際調査報告書

- (84) 指定国(表示のない限り、全ての種類の広域保護が可能): ARIPO(BW, GH, GM, KE, LS, MW, MZ, SD, SL,  
SZ, TZ, UG, ZM, ZW), ユーラシア(AM, AZ, BY, KG,

2文字コード及び他の略語については、定期発行される各PCTガゼットの巻頭に掲載されている「コードと略語のガイダンスノート」を参照。

## 明細書

## 復号装置および復号方法、並びにプログラム

## 技術分野

5 本発明は、復号装置および復号方法、並びにプログラムに関し、特に、低密度  
パリティ検査符号（LDPC 符号）による符号化が施された符号の復号を行う復号  
装置および復号方法、並びにプログラムに関する。

## 背景技術

10 近年、例えば、移動体通信や深宇宙通信といった通信分野、及び地上波又は衛  
星ディジタル放送といった放送分野の研究が著しく進められているが、それに伴  
い、誤り訂正符号化及び復号の効率化を目的として符号理論に関する研究も盛ん  
に行われている。

15 符号性能の理論的限界としては、いわゆるシャノン(C. E. Shannon)の通信  
路符号化定理によって与えられるシャノン限界が知られている。符号理論に関する  
研究は、このシャノン限界に近い性能を示す符号を開発することを目的として  
行われている。近年では、シャノン限界に近い性能を示す符号化方法として、例  
えば、並列連接疊み込み符号(PCCC(Parallel Concatenated Convolutional  
Codes))や、縦列連接疊み込み符号(SCCC(Serially Concatenated  
Convolutional Codes))といった、いわゆるターボ符号化(Turbo coding)と  
呼ばれる手法が開発されている。また、これらのターボ符号が開発される一方で、  
古くから知られる符号化方法である低密度パリティ検査符号(Low Density  
Parity Check codes)（以下、LDPC 符号という）が脚光を浴びつつある。

20 LDPC 符号は、R. G. Gallager による「R. G. Gallager, "Low  
Density Parity Check Codes", Cambridge, Massachusetts: M. I.  
T. Press, 1963」において最初に提案されたものであり、その後、「D. J.  
C. MacKay, "Good error correcting codes based on very sparse

matrices", Submitted to IEEE Trans. Inf. Theory, IT-45, pp. 399-431, 1999」や、「M. G. Luby, M. Mitzenmacher, M. A. Shokrollahi and D. A. Spielman, "Analysis of low density codes and improved designs using irregular graphs", in 5 Proceedings of ACM Symposium on Theory of Computing, pp. 249-258, 1998」等において再注目されるに至ったものである。

LDPC 符号は、近年の研究により、ターボ符号等と同様に、符号長を長くしていくにしたがって、シャノン限界に近い性能が得られることがわかりつつある。また、LDPC 符号は、最小距離が符号長に比例するという性質があることから、10 その特徴として、ブロック誤り確率特性がよく、さらに、ターボ符号等の復号特性において観測される、いわゆるエラーフロア現象が殆ど生じないことも利点として挙げられる。

以下、このような LDPC 符号について具体的に説明する。なお、LDPC 符号は、線形符号であり、必ずしも 2 元である必要はないが、ここでは、2 元であるもの 15 として説明する。

LDPC 符号は、その LDPC 符号を定義する検査行列 (parity check matrix) が疎なものであることを最大の特徴とするものである。ここで、疎な行列とは、行列のコンポーネントの "1" の個数が非常に少なく構成されるものであり、疎な検査行列を  $H$  で表すものとすると、そのような検査行列としては、例えば、図 1 20 に示すように、各列のハミング重み ("1" の数) (weight) が "3" であり、且つ、各行のハミング重みが "6" であるもの等がある。

このように、各行及び各列のハミング重みが一定である検査行列  $H$  によって定義される LDPC 符号は、レギュラー LDPC 符号と称される。一方、各行及び各列のハミング重みが一定でない検査行列  $H$  によって定義される LDPC 符号は、イレ 25 ギュラー LDPC 符号と称される。

このような LDPC 符号による符号化は、検査行列  $H$  に基づいて生成行列  $G$  を生成し、この生成行列  $G$  を 2 元の情報メッセージに対して乗算することによって

符号語を生成することで実現される。具体的には、LDPC 符号による符号化を行う符号化装置は、まず、検査行列  $H$  の転置行列  $H^T$  との間に、式  $GH^T=0$  が成立する生成行列  $G$  を算出する。ここで、生成行列  $G$  が、 $k \times n$  行列である場合には、  
5 符号化装置は、生成行列  $G$  に対して  $k$  ビットからなる情報メッセージ（ベクトル  $u$ ）を乗算し、 $n$  ビットからなる符号語  $c$  ( $=uG$ ) を生成する。この符号化装置によって生成された符号語は、値が“0”的符号ビットが“+1”に、値が“1”的符号ビットが“-1”にといったようにマッピングされて送信され、所定の通信路を介して受信側において受信されることになる。

一方、LDPC 符号の復号は、Gallager が確率復号(Probabilistic Decoding)  
10 と称して提案したアルゴリズムであって、バリアブルノード(variable node  
(メッセージノード(message node)とも呼ばれる。))と、チェックノード  
(check node)とからなる、いわゆるタナーグラフ(Tanner graph)上での確率  
伝播(belief propagation)によるメッセージ・パッシング・アルゴリズムによ  
って行うことが可能である。ここで、以下、適宜、バリアブルノードとチェック  
15 ノードを、単に、ノードともいう。

しかしながら、確率復号においては、各ノード間で受け渡されるメッセージが  
実数値であることから、解析的に解くためには、連続した値をとるメッセージの  
確率分布そのものを追跡する必要があり、非常に困難を伴う解析を必要とするこ  
とになる。そこで、Gallager は、LDPC 符号の復号アルゴリズムとして、アルゴ  
20 リズム A 又はアルゴリズム B を提案している。

LDPC 符号の復号は、一般的には、図 2 に示すような手順にしたがって行われ  
る。なお、ここでは、受信値を  $U_0(u_{0i})$  とし、チェックノードから出力されるメ  
ッセージを  $u_j$  とし、バリアブルノードから出力されるメッセージを  $v_i$  とする。  
また、ここでは、メッセージとは、値の“0”らしさを、いわゆる対数尤度比(log  
25 likelihood ratio)で表現した実数値である。

まず、LDPC 符号の復号においては、図 2 に示すように、ステップ S 1 1 にお  
いて、受信値  $U_0(u_{0i})$  が受信され、メッセージ  $u_j$  が“0”に初期化されるとともに、

繰り返し処理のカウンタとしての整数をとる変数 k が"0"に初期化され、ステップ S 1 2 に進む。ステップ S 1 2において、受信値  $U_0(u_{0i})$ に基づいて、式

(1) に示す演算を行うことによってメッセージ  $v_i$  が求められ、さらに、このメッセージ  $v_i$  に基づいて、式 (2) に示す演算を行うことによってメッセージ

5  $u_j$  が求められる。

$$v_i = u_{0i} + \sum_{j=1}^{d_v-1} u_j \quad \dots \quad (1)$$

$$\tanh\left(\frac{u_j}{2}\right) = \prod_{i=1}^{d_c-1} \tanh\left(\frac{v_i}{2}\right) \quad \dots \quad (2)$$

ここで、式 (1) と式 (2) における  $d_v$  と  $d_c$  は、それぞれ、検査行列 H の縦方向 (行方向) と横方向 (列方向) の"1"の個数を示す任意に選択可能とされる

10 パラメータであり、例えば、(3, 6) 符号の場合には、 $d_v=3$ ,  $d_c=6$  となる。

なお、式 (1) または (2) の演算においては、それぞれ、メッセージを出力しようとする枝(edge)から入力されたメッセージを、和または積演算のパラメータとしては用いないことから、和または積演算の範囲が、1 乃至  $d_v-1$  または 1 乃至  $d_c-1$  となっている。また、式 (2) に示す演算は、実際には、2 入力  $v_1$ ,  $v_2$  に対する 1 出力で定義される式 (3) に示す関数  $R(v_1, v_2)$  のテーブルを予め作成しておき、これを式 (4) に示すように連続的 (再帰的) に用いることによって行われる。

$$x = 2 \tanh^{-1} \{ \tanh(v_1/2) \tanh(v_2/2) \} = R(v_1, v_2) \quad \dots \quad (3)$$

$$u_j = R(v_1, R(v_2, R(v_3, \dots R(v_{d_c-2}, R(v_{d_c-1})))) \quad \dots \quad (4)$$

20 ステップ S 1 2 では、さらに、変数 k が"1"だけインクリメントされ、ステップ S 1 3 に進む。ステップ S 1 3 では、変数 k が所定の繰り返し復号回数 N 以上であるか否かが判定される。ステップ S 1 3 において、変数 k が N 以上ではないと判定された場合、ステップ S 1 2 に戻り、以下、同様の処理が繰り返され

る。

また、ステップ S 1 3において、変数 k が N 以上であると判定された場合、ステップ S 1 4に進み、式（5）に示す演算を行うことによって最終的に出力する復号結果としてのメッセージ v が求められて出力され、LDPC 符号の復号処理

5 が終了する。

$$v = u_{0i} + \sum_{j=1}^{d_v} u_j \quad \dots \quad (5)$$

ここで、式（5）の演算は、式（1）の演算とは異なり、バリアブルノードに接続している全ての枝からの入力メッセージを用いて行われる。

このような LDPC 符号の復号は、例えば(3, 6)符号の場合には、図 3 に示すよ  
10 うに、各ノード間でメッセージの授受が行われる。なお、図 3 における“=”で示  
すノード（バリアブルノード）では、式（1）に示した演算が行われ、“+”で示  
すノード（チェックノード）では、式（2）に示した演算が行われる。特に、アルゴリズム Aにおいては、メッセージを 2 元化し、“+”で示すノードにて、 $d_c - 1$   
個の入力メッセージの排他的論理和演算を行い、“=”で示すノードにて、受信値  
15 R に対して、 $d_c - 1$  個の入力メッセージが全て異なるビット値であった場合には、  
符号を反転して出力する。

また、一方で、近年、LDPC 符号の復号の実装法に関する研究も行われている。  
実装方法について述べる前に、まず、LDPC 符号の復号を模式化して説明する。

図 4 は、(3, 6)LDPC 符号（符号化率 1/2、符号長 12）の検査行列(parity  
20 check matrix)の例である。LDPC 符号の検査行列は、図 5 のように、タナーグラフを用いて書き表すことができる。ここで、図 5 において、“+”で表わされるのが、チェックノードであり、“=”で表わされるのが、バリアブルノードである。チェックノードとバリアブルノードは、それぞれ、検査行列の行と列に対応する。チェックノードとバリアブルノードとの間の結線は、枝(edge)であり、検査行  
25 列の“1”に相当する。即ち、検査行列の第 j 行第 i 列のコンポーネントが 1 である場合には、図 5 において、上から i 番目のバリアブルノード (“=”のノード)

と、上から  $j$  番目のチェックノード ("+" のノード) とが、枝により接続される。枝は、バリアブルノードに対応する符号ビットが、チェックノードに対応する拘束条件を持つことを表わす。なお、図 5 は、図 4 の検査行列のタナーグラフとなっている。

5 LDPC 符号の復号方法であるサムプロダクトアルゴリズム (Sum Product Algorithm) は、バリアブルノードの演算とチェックノードの演算とを繰り返し行う。

バリアブルノードでは、図 6 のように、式 (1) の演算を行う。すなわち、図 6において、計算しようとしている枝に対応するメッセージ  $v_i$  は、バリアブルノードに繋がっている残りの枝からのメッセージ  $u_1$  および  $u_2$  と、受信情報  $u_{0i}$  10 を用いて計算される。他の枝に対応するメッセージも同様に計算される。

チェックノードの演算について説明する前に、式 (2) を、式  $a \times b = \exp\{\ln(|a|) + \ln(|b|)\} \times \text{sign}(a) \times \text{sign}(b)$  の関係を用いて、式 (6) の 15 ように書き直す。但し、 $\text{sign}(x)$  は、 $x \geq 0$  のとき 1 であり、 $x < 0$  のとき -1 である。

$$\begin{aligned}
 u_j &= 2 \tanh^{-1} \left( \prod_{i=1}^{d_c-1} \tanh \left( \frac{v_i}{2} \right) \right) \\
 &= 2 \tanh^{-1} \left[ \exp \left\{ \sum_{i=1}^{d_c-1} \ln \left( \left| \tanh \left( \frac{v_i}{2} \right) \right| \right) \right\} \times \prod_{i=1}^{d_c-1} \text{sign} \left( \tanh \left( \frac{v_i}{2} \right) \right) \right] \\
 &= 2 \tanh^{-1} \left[ \exp \left\{ - \left( \sum_{i=1}^{d_c-1} -\ln \left( \tanh \left( \frac{|v_i|}{2} \right) \right) \right) \right\} \right] \times \prod_{i=1}^{d_c-1} \text{sign}(v_i) \\
 &\quad \cdots \quad (6)
 \end{aligned}$$

更に、 $x \geq 0$ において、 $\phi(x) = \ln(\tanh(x/2))$  と定義すると、 $\phi^{-1}(x) = 2 \tanh^{-1}(e^{-x})$  であるから、式 (6) は、式 (7) のように書くことができる。

$$u_j = \phi^{-1} \left( \sum_{i=1}^{d_o-1} \phi(|v_i|) \right) \times \prod_{i=1}^{d_c-1} \text{sign}(v_i) \quad \dots \quad (7)$$

チェックノードでは、図7のように、式(7)の演算を行う。すなわち、図7において、計算しようとしている枝に対応するメッセージ  $u_j$  は、チェックノードに繋がっている残りの枝からのメッセージ  $v_1, v_2, v_3, v_4, v_5$  を用いて計算される。

5 他の枝に対応するメッセージも同様に計算される。

なお、関数  $\phi(x)$  は、 $\phi(x) = \ln((e^x + 1) / (e^x - 1))$  とも表すことができ、 $x > 0$ において、 $\phi(x) = \phi^{-1}(x)$  である。関数  $\phi(x)$  および  $\phi^{-1}(x)$  をハードウェアに実装する際には、LUT (Look Up Table) を用いて実装される場合があるが、両者共に同一の LUT となる。

10 サムプロダクトアルゴリズムをハードウェアに実装する場合、式(1)で表わされるバリアブルノード演算および式(7)で表わされるチェックノード演算とを、適度な回路規模と動作周波数で繰り返し行うことが必要である。

復号装置の実装の例として、まず、単純に各ノードの演算を一つずつ順次行うことによって復号を行う場合 (full serial decoding) の実装法について説明  
15 する。

なお、ここでは、例えば、図8の、30(行) × 90(列)の検査行列で表現される符号 (符号化率 2/3、符号長 90) を復号することとする。図8の検査行列の1の数は 269 であり、従って、そのタナーグラフでは、枝の数は 269 個となる。ここで、図8の検査行列では、0を、"."で表現している。

20 図9は、LDPC 符号の1回復号を行う復号装置の構成例を示している。

図9の復号装置では、その動作する1クロック (clock)ごとに、1つの枝に対応するメッセージが計算される。

即ち、図9の復号装置は、2つの枝用メモリ 100 および 102、1つのチェックノード計算器 101、1つのバリアブルノード計算器 103、1つの受信用メモリ 104、1つの制御部 105 からなる。  
25

図9の復号装置では、枝用メモリ 100 または 102 からメッセージデータが

1つずつ読み出され、そのメッセージデータを用いて、所望の枝に対応するメッセージデータが計算される。そして、その計算によって求められたメッセージデータが1つずつ後段の枝用メモリ102または100に格納されていく。繰り返し復号を行う際には、この1回復号を行う図9の復号装置を複数個縦列に連接するか、もしくは図9の復号装置を繰り返し用いることによって、繰り返し復号を実現する。なお、ここでは、例えば、図9の復号装置が複数個接続されているものとする。

枝用メモリ100は、前段の復号装置（図示せず）のバリアブルノード計算器103から供給されるメッセージD100を、後段のチェックノード計算器101が読み出す順番に格納していく。そして、枝用メモリ100は、チェックノード計算のフェーズでは、メッセージD100を、格納してある順番通りに、メッセージD101として、チェックノード計算器101に供給する。

チェックノード計算器101は、制御部105から供給される制御信号D106に基づき、枝用メモリ100から供給されるメッセージD101を用いて、式（7）に従って演算を行い、その演算によって求められたメッセージD102を、後段の枝用メモリ102に供給する。

枝用メモリ102は、前段のチェックノード計算器101から供給されるメッセージD102を、後段のバリアブルノード計算器103が読み出す順番に格納していく。そして、枝用メモリ102は、バリアブルノード計算のフェーズでは、メッセージD102を、格納してある順番通りに、メッセージD103として、バリアブルノード計算器103に供給する。

さらに、バリアブルノード計算器103には、制御部105から制御信号D107が供給されるとともに、受信用メモリ104から受信データD104が供給される。バリアブルノード計算器103は、制御信号D107に基づき、枝用メモリ100から供給されるメッセージD103と受信用メモリ100から供給される受信データD104を用い、式（1）に従って演算を行い、その演算の結果得られるメッセージD105を、図示せぬ後段の復号装置の枝用メモリ100に供給する。

受信用メモリ 104 には、LDPC 符号化された受信データ（LDPC 符号）が格納される。制御部 105 は、バリアブルノード演算を制御する制御信号 D106 と、チェックノード演算を制御する制御信号 D107 を、それぞれチェックノード計算器 101 とバリアブルノード計算器 103 に供給する。制御部 105 は、枝用メモリ 100 に全ての枝のメッセージが格納されたとき、チェックノード計算器 101 に制御信号 D106 を供給し、枝用メモリ 102 に全ての枝のメッセージが格納されたとき、バリアブルノード計算器 103 に制御信号 D107 を供給する。

図 10 は、チェックノード演算を 1 つずつ行う図 9 のチェックノード計算器 101 の構成例を示している。

なお、図 10 では、各メッセージが符号ビットを合わせて合計 6 ビット(bit)に量子化されているものとして、チェックノード計算器 101 を表している。また、図 10 では、図 8 の検査行列で表わされる LDPC 符号のチェックノード演算が行われる。さらに、図 10 のチェックノード演算器 101 には、クロック ck が供給され、このクロック ck は、必要なブロックに供給されるようになってい。そして、各ブロックは、クロック ck に同期して処理を行う。

図 10 のチェックノード計算器 101 は、制御部 105 から供給される、例えば、1 ビットの制御信号 D106 に基づき、枝用メモリ 100 から 1 つずつ読み込まれるメッセージ D101 を用いて、式 (7) にしたがって演算を行う。

即ち、チェックノード計算器 101 では、検査行列の各列に対応するバリアブルノードからの 6 ビットのメッセージ D101 (メッセージ  $v_i$ ) が 1 つずつ読み込まれ、その下位ビットである絶対値 D122 ( $|v_i|$ ) が LUT 121 に、その最上位ビットである符号ビット D121 が EXOR 回路 129 と FIFO(First In First Out) メモリ 133 にそれぞれ供給される。また、チェックノード計算器 101 には、制御部 105 から制御信号 D106 が供給され、その制御信号 D106 は、セレクタ 124 とセレクタ 131 に供給される。

LUT 121 は、絶対値 D122 ( $|v_i|$ ) に対して、式 (7) における  $\phi(|v_i|)$  の演算を行った 5 ビットの演算結果 D123 ( $\phi(|v_i|)$ ) を読み出し、加算器 122 と

FIFO メモリ 127 に供給する。

加算器 122 は、演算結果 D123 ( $\phi(|v_i|)$ ) とレジスタ 123 に格納されている 9 ビットの値 D124 とを加算することにより、演算結果 D123 を積算し、その結果得られる 9 ビットの積算値をレジスタ 123 に再格納する。なお、検査行  
5 列の 1 行に亘る全ての枝からのメッセージ D101 の絶対値 D122 ( $|v_i|$ ) に対する演算結果が積算された場合、レジスタ 123 はリセットされる。

検査行列の 1 行に亘るメッセージ D101 が 1 つずつ読み込まれ、レジスタ 123 に 1 行分の演算結果 D123 が積算された積算値が格納された場合、制御部 105 から供給される制御信号 D106 は、0 から 1 に変化する。例えば、行の重み  
10 (row weight) が「9」である場合、制御信号 D106 は、1 から 8 クロック目までは、「0」となり、9 クロック目では「1」となる。

制御信号 D106 が「1」の場合、セレクタ 124 は、レジスタ 123 に格納されている値、即ち、検査行列の 1 行に亘る全ての枝からのメッセージ D101 (メッセージ  $v_i$ ) から求められた  $\phi(|v_i|)$  が積算された 9 ビットの値 D124 ( $i = 1$  から  $i = d$  までの  $\sum \phi(|v_i|)$ ) を選択し、値 D125 として、レジスタ 125 に出力して格納させる。レジスタ 125 は、格納している値 D125 を、9 ビットの値 D126 として、セレクタ 124 と加算器 126 に供給する。制御信号 D106 が「0」の場合、セレクタ 124 は、レジスタ 125 から供給された値 D126 を選択し、レジスタ 125 に出力して再格納させる。即ち、検査行列の 1 行に亘る全ての枝からのメッセージ D101 (メッセージ  $v_i$ ) から求められた  $\phi(|v_i|)$  が積算されるまで、レジスタ 125 は、前回積算された  $\phi(|v_i|)$  を、セレクタ 124 と加算器 126 に供給する。

一方、FIFO メモリ 127 は、レジスタ 125 から新たな値 D126 ( $i = 1$  から  $i = d$  までの  $\sum \phi(|v_i|)$ ) が出力されるまでの間、LUT 121 が出力した演算結果 D123 ( $\phi(|v_i|)$ ) を遅延し、5 ビットの値 D127 として減算器 126 に供給する。減算器 126 は、レジスタ 125 から供給された値 D126 から、FIFO メモリ 127 から供給された値 D127 を減算し、その減算結果を、5 ビットの減算値

D128 として LUT 1 2 8 に供給する。即ち、減算器 1 2 6 は、検査行列の 1 行に亘る全ての枝からのメッセージ D101 (メッセージ  $v_i$ ) から求められた  $\phi(|v_i|)$  の積算値から、求めたい枝からのメッセージ D101 (メッセージ  $v_i$ ) から求められた  $\phi(|v_i|)$  を減算して、その減算値 ( $i = 1$  から  $i = d_c - 1$  までの

5  $\sum \phi(|v_i|)$ ) を減算値 D128 として LUT 1 2 8 に供給する。

LUT 1 2 8 は、減算値 D128 ( $i = 1$  から  $i = d_c - 1$  までの  $\sum \phi(|v_i|)$ ) に対して、式 (7) における  $\phi^{-1}(\sum \phi(|v_i|))$  の演算を行った 5 ビットの演算結果 D129 ( $\phi^{-1}(\sum \phi(|v_i|))$ ) を出力する。

以上の処理と並行して、EXOR 回路 1 2 9 は、レジスタ 1 3 0 に格納されている 1 ビットの値 D131 と符号ビット D121 との排他的論理和を演算することにより、符号ビットどうしの乗算を行い、1 ビットの乗算結果 D130 をレジスタ 1 3 0 に再格納する。なお、検査行列の 1 行に亘る全ての枝からのメッセージ D101 の符号ビット D121 が乗算された場合、レジスタ 1 3 0 はリセットされる。

検査行列の 1 行に亘る全ての枝からのメッセージ D101 の符号ビット D121 が乗算された乗算結果 D130 ( $i = 1$  から  $d_c$  までの  $\prod \text{sign}(v_i)$ ) がレジスタ 1 3 0 に格納された場合、制御部 1 0 5 から供給される制御信号 D106 は、「0」から「1」に変化する。

制御信号 D106 が「1」の場合、セレクタ 1 3 1 は、レジスタ 1 3 0 に格納されている値、即ち、検査行列の 1 行に亘る全ての枝からのメッセージ D101 の符号ビット D121 が乗算された値 D131 ( $i = 1$  から  $i = d_c$  までの  $\prod \text{sign}(v_i)$ ) を選択し、1 ビットの値 D132 としてレジスタ 1 3 2 に出力して格納させる。レジスタ 1 3 2 は、格納している値 D132 を、1 ビットの値 D133 としてセレクタ 1 3 1 と EXOR 回路 1 3 4 に供給する。制御信号 D106 が「0」の場合、セレクタ 1 3 1 は、レジスタ 1 3 2 から供給された値 D133 を選択し、レジスタ 1 3 2 に output して再格納させる。即ち、検査行列の 1 行に亘る全ての枝からのメッセージ D101 (メッセージ  $v_i$ ) の符号ビット D121 が乗算されるまで、レジスタ 1 3 2 は、前回格納した値を、セレクタ 1 3 1 と EXOR 回路 1 3 4 に供給する。

一方、FIFO メモリ 133 は、レジスタ 132 から新たな値 D133 ( $i = 1$  から  $i = d$  までの  $\prod \text{sign}(v_i)$ ) が EXOR 回路 134 に供給されるまでの間、符号ビット D121 を遅延し、1 ビットの値 D134 として EXOR 回路 134 に供給する。

EXOR 回路 134 は、レジスタ 132 から供給された値 D133 と、FIFO メモリ 133 から供給された値 D134 との排他的論理和を演算することにより、値 D133 を、値 D134 で除算し、1 ビットの除算結果を除算値 D135 として出力する。即ち、EXOR 回路 134 は、検査行列の 1 行に亘る全ての枝からのメッセージ D101 の符号ビット D121 ( $\text{sign}(|v_i|)$ ) の乗算値を、求めたい枝からのメッセージ D101 の符号ビット D121 ( $\text{sign}(|v_i|)$ ) で除算して、その除算値 ( $i = 1$  から  $i = d - 1$  までの  $\prod \text{sign}(|v_i|)$ ) を除算値 D135 として出力する。

チェックノード計算器 101 では、LUT 128 から出力された 5 ビットの演算結果 D129 を下位 5 ビットとともに、EXOR 回路 134 から出力された 1 ビットの除算値 D135 を最上位ビットとする合計 6 ビットがメッセージ D102 (メッセージ  $u_j$ ) として出力される。

以上のように、チェックノード計算器 101 では、式 (7) の演算が行われ、メッセージ  $u_j$  が求められる。

なお、図 8 の検査行列の行の重みの最大は 9 であるため、即ち、チェックノードに供給されるメッセージの最大数は 9 であるため、チェックノード計算器 101 は、9 個のメッセージ ( $\phi(|v_i|)$ ) を遅延させる FIFO メモリ 127 と FIFO メモリ 133 を有している。行の重みが 9 未満の行のメッセージを計算するときには、FIFO メモリ 127 と FIFO メモリ 133 における遅延量が、その行の重みの値に減らされる。

図 11 は、バリアブルノード演算を 1 つずつ行う図 9 のバリアブルノード計算器 103 の構成例を示している。

なお、図 11 では、各メッセージが符号ビットを合わせて合計 6 ビット (bit) に量子化されているものとして、バリアブルノード計算器 103 を表している。また、図 11 では、図 8 の検査行列で表わされる LDPC 符号のバリアブルノード

演算が行われる。さらに、図11のバリアブルノード計算機103には、クロック $c_k$ が供給され、クロック $c_k$ は、必要なブロックに供給されるようになっていて、そして、各ブロックは、クロック $c_k$ に同期して処理を行う。

図11のバリアブルノード計算器103は、制御部105から供給される、例  
5 えば、1ビットの制御信号D107に基づき、枝用メモリ102から1つずつ読み  
込まれるメッセージD103と、受信用メモリ104から読み込まれる受信データ  
D104を用いて、式(1)にしたがって演算を行う。

即ち、バリアブルノード計算器103では、検査行列の各行に対応するチェックノードからの6ビットのメッセージD103(メッセージ $u_j$ )が1つずつ読み込まれ、そのメッセージD103が、加算器151とFIFOメモリ155に供給される。また、バリアブルノード計算器103では、受信用メモリ104から6ビットの受信データD104が1つずつ読み込まれ、加算器156に供給される。さらに、バリアブルノード計算器103には、制御部105から制御信号D107が供給され、その制御信号D107は、セレクタ153に供給される。  
10  
15

加算器151は、メッセージD103(メッセージ $u_j$ )とレジスタ152に格納されている9ビットの値D151とを加算することにより、メッセージD103を積算し、その結果得られる9ビットの積算値を、レジスタ152に再格納する。なお、検査行列の1列に亘る全ての枝からのメッセージD103が積算された場合、レジスタ152はリセットされる。

検査行列の1列に亘るメッセージD103が1つずつ読み込まれ、レジスタ152に1列分のメッセージD103が積算された値が格納された場合、制御部105から供給される制御信号D107は、「0」から「1」に変化する。例えば、列の重みが「5」である場合、制御信号D107は、1から4クロック目までは「0」となり、5クロック目では「1」となる。  
20  
25

制御信号D107が「1」の場合、セレクタ153は、レジスタ152に格納されている値、即ち、検査行列の1列に亘る全ての枝からのメッセージD103(メッセージ $u_j$ )が積算された9ビットの値D151( $j = 1$ から $d_v$ までの $\sum u_j$ )を選

択し、レジスタ 154 に出力して格納させる。レジスタ 154 は、格納している値 D151 を、9 ビットの値 D152 として、セレクタ 153 と加減算器 156 に供給する。制御信号 D107 が「0」の場合、セレクタ 153 は、レジスタ 154 から供給された値 D152 を選択し、レジスタ 154 に出力し再格納させる。即ち、  
5 検査行列の 1 列に亘る全ての枝からのメッセージ D103 (メッセージ  $u_j$ ) が積算されるまで、レジスタ 154 は、前回積算された値を、セレクタ 153 と加減算器 156 に供給する。

一方、FIFO メモリ 155 は、レジスタ 154 から新たな値 D152 ( $j = 1$  から  $d_v$  までの  $\sum u_j$ ) が出力されるまでの間、チェックノードからのメッセージ D103 を遅延し、6 ビットの値 D153 として加減算器 156 に供給する。加減算器 156 は、レジスタ 154 から供給された値 D152 から、FIFO メモリ 155 から供給された値 D153 を減算する。即ち、加減算器 156 は、検査行列の 1 列に亘る全ての枝からのメッセージ D103 (メッセージ  $u_j$ ) の積算値から、求めたい枝からのメッセージ  $u_j$  を減算して、その減算値 ( $j = 1$  から  $d_v - 1$  までの  $\sum u_j$ ) を求める。さらに、加減算器 156 には、その減算値 ( $j = 1$  から  $d_v - 1$  までの  $\sum u_j$ ) に、受信用メモリ 104 から供給された受信データ D104 を加算して、その結果得られる 6 ビットの値をメッセージ D105 (メッセージ  $v_i$ ) として出力する。  
15

以上のように、バリアブルノード計算器 103 では、式 (1) の演算が行われ、  
20 メッセージ  $v_i$  が求められる。

なお、図 8 の検査行列の列の重みの最大は 5 であるため、即ち、バリアブルノードに供給されるメッセージの最大数は 5 であるため、バリアブルノード計算器 103 は、5 個のメッセージ ( $u_j$ ) を遅延させる FIFO メモリ 155 を有している。列の重みが 5 未満の列のメッセージを計算するときには、FIFO メモリ 155 における遅延量が、その列の重みの値に減らされる。  
25

図 9 の復号装置では、検査行列の重みにしたがって、制御部 105 から制御信号が与えられる。そして、図 9 の復号装置によれば、枝用メモリ 100 および 1

02、並びにチェックノード計算器101およびバリアブルノード計算器103のFIFOメモリ127, 133, 155の容量さえ足りれば、制御信号のみを変えることで様々な検査行列のLDPC符号を復号することができる。

なお、図示しないが、図9の復号装置において、復号の最終段においては、式  
5 (1) のバリアブルノード演算の代わりに、式(5)の演算が行われ、その演算結果が、最終的な復号結果として出力される。

図9の復号装置を繰り返し用いて、LDPC符号を復号する場合には、チェックノード演算とバリアブルノード演算とが交互に行われる。即ち、図9の復号装置では、チェックノード計算器101によるチェックノード演算の結果を用いて、  
10 バリアブルノード計算器103によりバリアブルノード演算が行われ、バリアブルノード計算器103によるバリアブルノード演算の結果を用いて、チェックノード計算器101によりチェックノード演算が行われる。

従って、269の枝を有する図8の検査行列を用いた1回の復号に、  
269×2=538クロック(clock)を必要とする。例えば、50回の繰り返し復号を行いうためには、符号長である90個の符号(受信データ)を1フレームとして、  
15 その1フレームを受信する間に、538×50=26900クロック動作することが必要であり、受信周波数の約300( $\approx 26900/90$ )倍の高速動作が必要になる。受信周波数が数十MHzであるとすると、GHz以上の速度での動作を要求されることになる。

20 また、図9の復号装置を、例えば、50台連接して、LDPC符号を復号する場合には、1フレーム(frame)目のバリアブルノード演算を行っている間に、2フレーム目のチェックノード演算を行い、3フレーム目のバリアブルノード演算を行う、というように、複数のバリアブルノード演算とチェックノード演算とを同時にを行うことができる。この場合、90個の符号を受信する間に、269個の枝を計算すればよいので、復号装置は、受信周波数の約3( $\approx 269/90$ )倍の周波数で動作すればよいことになり、十分に実現可能である。しかしながら、この場合、回路規模が、単純には、図9の復号装置の50倍になる。

次に、全ノードの演算を同時に行うことによって復号を行う場合(full parallel decoding)の復号装置の実装法について説明する。

この実装法については、例えば、C. Howland and A. Blanksby, "Parallel Decoding Architectures for Low Density Parity Check Codes", Symposium on Circuits and Systems, 2001 に記載されている。

図12A乃至図12Cは、図8の検査行列で表現される符号（符号化率2/3、符号長90）を復号する復号装置の一例の構成を示している。なお、図12Aは、復号装置全体の構成を示している。また、図12Bは、図12Aの復号装置の点線Bで囲まれた図中上部の詳細構成を示し、図12Cは、図12Aの復号装置の点線Cで囲まれた図中下部の詳細構成を示している。

図12A乃至図12Cの復号装置は、1つの受信用メモリ205、2つの枝入れ替え装置200および203、2つの枝用メモリ202および206、30個のチェックノード計算器201<sub>1</sub>乃至201<sub>30</sub>から構成されるチェックノード計算器201、90個のバリアブルノード計算器204<sub>1</sub>乃至204<sub>90</sub>から構成されるバリアブルノード計算器204からなる。

図12A乃至図12Cの復号装置では、枝用メモリ202または206から、269個ある枝に対応するメッセージデータを全て同時に読み出し、そのメッセージデータを用いて、269個の枝に対応する新たなメッセージデータを演算する。さらに、その演算の結果求められた新たなメッセージデータが全て同時に後段の枝用メモリ206または202に格納されていく。そして、図12A乃至図12Cの復号装置を繰り返し用いることで繰り返し復号が実現される。以下、各部について詳細に説明する。

枝用メモリ206は、前段のバリアブルノード計算器204<sub>1</sub>乃至204<sub>90</sub>からのメッセージD206<sub>1</sub>乃至D206<sub>90</sub>を全て同時に格納し、次の時刻（次のクロックのタイミング）に、メッセージD206<sub>1</sub>乃至D206<sub>90</sub>を、メッセージD207<sub>1</sub>乃至D207<sub>90</sub>として読み出し、次段の枝入れ替え装置200に、メッセージ200(D200<sub>1</sub>乃至D200<sub>90</sub>)として供給する。枝入れ替え装置200は、枝用メモリ206から

供給されたメッセージ  $D200_1$  乃至  $D200_{30}$  の順番を、図 8 の検査行列にしたがって並び替え（入れ替え）、チェックノード計算器  $201_1$  乃至  $201_{30}$  に、メッセージ  $D201_1$  乃至  $D201_{30}$  として供給する。

チェックノード計算器  $201_1$  乃至  $201_{30}$  は、枝入れ替え装置 200 から供給されるメッセージ  $D201_1$  乃至  $D201_{30}$  を用いて式（7）にしたがって演算を行い、その演算の結果得られるメッセージ  $D202_1$  乃至  $D202_{30}$  を、枝用メモリ 202 に供給する。  
5

枝用メモリ 202 は、前段のチェックノード計算器  $201_1$  乃至  $201_{30}$  から供給されるメッセージ  $D202_1$  乃至  $D202_{30}$  を全て同時に格納し、次の時刻に、その 10 すべてのメッセージ  $D202_1$  乃至  $D202_{30}$  を、メッセージ  $D203_1$  乃至  $D203_{30}$  として、次段の枝入れ替え装置 203 に供給する。

枝入れ替え装置 203 は、枝用メモリ 202 から供給されたメッセージ  $D203_1$  乃至  $D203_{30}$  の順番を図 8 の検査行列にしたがって並び替え、バリアブルノード計算器  $204_1$  乃至  $204_{30}$  に、メッセージ  $D204_1$  乃至  $D204_{30}$  として供給する。  
15

バリアブルノード計算器  $204_1$  乃至  $204_{30}$  は、枝入れ替え装置 203 から供給されるメッセージ  $D204_1$  乃至  $D204_{30}$  と、受信用メモリ 205 から供給される受信データ  $D205_1$  乃至  $D205_{30}$  を用いて式（1）にしたがって演算を行い、その演算の結果得られるメッセージ  $D206_1$  乃至  $D206_{30}$  を、次段の枝用メモリ 206 に供給する。  
20

図 13 は、チェックノード演算を同時に行う図 12A 乃至図 12C のチェックノード計算器  $201_m$  ( $m = 1, 2, \dots, 30$ ) の構成例を示している。

図 13 のチェックノード計算器  $201_m$  では、図 10 のチェックノード計算器 101 と同様にして、式（7）のチェックノード演算が行われるが、そのチェックノード演算が、すべての枝について同時に行われる。

即ち、図 13 のチェックノード計算器  $201_m$  では、枝入れ替え装置 200 から供給される図 8 の検査行列の各列に対応するバリアブルノードからのメッセージ  $D221_1$  乃至  $D221_v_i$  ( $v_i$ ) が全て同時に読み込まれ、それぞれの下位 5 ビットで  
25

ある絶対値 D<sub>222<sub>1</sub></sub> 乃至 D<sub>222<sub>9</sub></sub> ( $|v_i|$ ) が LUT 2 2 1<sub>1</sub> 乃至 2 2 1<sub>9</sub> にそれぞれ供給される。また、メッセージ D<sub>221<sub>1</sub></sub> 乃至 D<sub>221<sub>9</sub></sub> ( $v_i$ ) の最上位ビットである 1 ビットの符号ビット D<sub>223<sub>1</sub></sub> 乃至 D<sub>223<sub>9</sub></sub> が、EXOR 回路 2 2 6<sub>1</sub> 乃至 2 2 6<sub>9</sub> にそれぞれ供給されるとともに、EXOR 回路 2 2 5 に供給される。

5 LUT 2 2 1<sub>1</sub> 乃至 2 2 1<sub>9</sub> は、絶対値 D<sub>222<sub>1</sub></sub> 乃至 D<sub>222<sub>9</sub></sub> ( $|v_i|$ ) に対して、式 (7) における  $\phi(|v_i|)$  の演算を行った 5 ビットの演算結果 D<sub>224<sub>1</sub></sub> 乃至 D<sub>224<sub>9</sub></sub> ( $\phi(|v_i|)$ ) をそれぞれ読み出し、それを減算器 2 2 3<sub>1</sub> 乃至 2 2 3<sub>9</sub> に供給する。また、LUT 2 2 1<sub>1</sub> 乃至 2 2 1<sub>9</sub> は、演算結果 D<sub>224<sub>1</sub></sub> 乃至 D<sub>224<sub>9</sub></sub> ( $\phi(|v_i|)$ ) を加算器 2 2 2 に供給する。

10 加算器 2 2 2 は、演算結果 D<sub>224<sub>1</sub></sub> 乃至 D<sub>224<sub>9</sub></sub> ( $\phi(|v_i|)$ ) の値の総和 (1 行分の演算結果の総和) を演算し、9 ビットの演算結果 D<sub>225</sub> ( $i = 1$  から 9 の  $\sum \phi(|v_i|)$ ) を、減算器 2 2 3<sub>1</sub> 乃至 2 2 3<sub>9</sub> に供給する。減算器 2 2 3<sub>1</sub> 乃至 2 2 3<sub>9</sub> は、演算結果 D<sub>225</sub> から、演算結果 D<sub>224<sub>1</sub></sub> 乃至 D<sub>224<sub>9</sub></sub> ( $\phi(|v_i|)$ ) をそれぞれ減算し、5 ビットの減算値 D<sub>227<sub>1</sub></sub> 乃至 D<sub>227<sub>9</sub></sub> を、LUT 2 2 4<sub>1</sub> 乃至 2 2 4<sub>9</sub> に供給する。即ち、減算器 2 2 3<sub>1</sub> 乃至 2 2 3<sub>9</sub> は、全ての枝からのメッセージ  $v_i$  から求められた  $\phi(|v_i|)$  の積算値から、求めたい枝からのメッセージ  $v_i$  から求められた  $\phi(|v_i|)$  を減算して、その減算値 D<sub>227<sub>1</sub></sub> 乃至 D<sub>227<sub>9</sub></sub> ( $i = 1$  から 8 までの  $\sum \phi(|v_i|)$ ) を LUT 2 2 4<sub>1</sub> 乃至 2 2 4<sub>9</sub> にそれぞれ供給する。LUT 2 2 4<sub>1</sub> 乃至 2 2 4<sub>9</sub> は、減算値 D<sub>227<sub>1</sub></sub> 乃至 D<sub>227<sub>9</sub></sub> に対して、式 (7) における  $\phi^{-1}(\sum \phi(|v_i|))$  の演算を行った 5 ビットの演算結果 D<sub>228<sub>1</sub></sub> 乃至 D<sub>228<sub>9</sub></sub> を読み出して出力する。

一方、EXOR 回路 2 2 5 は、全ての符号ビット D<sub>223<sub>1</sub></sub> 乃至 D<sub>223<sub>9</sub></sub> の排他的論理和を演算することにより、符号ビット D<sub>223<sub>1</sub></sub> 乃至 D<sub>223<sub>9</sub></sub> の乗算を行い、1 ビットの乗算値 D<sub>226</sub> (1 行分の符号ビットの乗算値 ( $i = 1$  から 9 までの  $\prod sign(v_i)$ )) を EXOR 回路 2 2 6<sub>1</sub> 乃至 2 2 6<sub>9</sub> にそれぞれ供給する。EXOR 回路 2 2 6<sub>1</sub> 乃至 2 2 6<sub>9</sub> は、乗算値 D<sub>226</sub> と符号ビット D<sub>223<sub>1</sub></sub> 乃至 D<sub>223<sub>9</sub></sub> それぞれとの排他的論理を演算することにより、乗算値 D<sub>226</sub> を、符号ビット D<sub>223<sub>1</sub></sub> 乃至 D<sub>223<sub>9</sub></sub>

それぞれで除算した 1 ビットの除算値  $D229_1$  乃至  $D229_9$  ( $i = 1$  から 8 までの  $\prod \text{sign}(v_i)$ ) を求めて出力する。

チェックノード計算器  $201_m$  では、LUT  $224_1$  乃至  $224_9$  から出力された 5 ビットの演算結果  $D228_1$  乃至  $D228_9$  それを下位 5 ビットとともに、

5 EXOR 回路  $226_1$  乃至  $226_9$  から出力された除算値  $D229_1$  乃至  $D229_9$  それを最上位ビットとする合計 6 ビットが、チェックノード演算の結果得られるメッセージ  $D230_1$  乃至  $D230_9$  として出力される。

以上のように、チェックノード計算器  $201_m$  では、式 (7) の演算が行われ、メッセージ  $u_j$  が求められる。

10 なお、図 13 では、各メッセージが符号ビットを合わせて合計 6 ビットに量子化されているものとして、チェックノード計算器  $201_m$  を表している。また、図 13 の回路は 1 つのチェックノードに相当する。ここで処理の対象としている図 8 の検査行列については、その行数である 30 行のチェックノードが存在するため、図 12A 乃至 図 12C の復号装置は、図 13 に示したようなチェックノード計算器  $201_m$  を 30 個有している。

ここで、図 13 のチェックノード計算器  $201_m$  では、9 個のメッセージを同時に計算することができる。そして、ここで処理の対象としている図 8 の検査行列の行の重みは、第 1 行が 8 で、第 2 乃至 第 30 行が 9 であるため、即ち、チェックノードに供給されるメッセージの数が、8 のケースが 1 つと、9 のケースが 29 あるため、チェックノード計算器  $201_1$  は、図 13 の回路と同様の 8 つのメッセージを同時に計算することができる回路構成となっており、残りのチェックノード計算器  $201_2$  乃至  $201_{30}$  は、図 13 の回路と同一構成となっている。

図 14 は、バリアブルノード演算を同時に図 12A 乃至 図 12C のバリアブルノード計算器  $204_p$  ( $p = 1, 2, \dots, 90$ ) の構成例を示している。

25 図 14 のバリアブルノード計算器  $204_p$  では、図 11 のバリアブルノード計算器  $103$  と同様にして、式 (1) のバリアブルノード演算が行われるが、そのバリアブルノード演算が、すべての枝について同時に行われる。

即ち、図 1.4 のバリアブルノード計算器 204<sub>p</sub> では、枝入れ替え装置 203 から供給される、検査行列の各行に対応するチェックノードからの 6 ビットのメッセージ D251<sub>1</sub> 乃至 D251<sub>5</sub> (メッセージ u<sub>j</sub>) が全て同時に読み込まれ、それぞれ加算器 252<sub>1</sub> 乃至 252<sub>5</sub> に供給されるとともに、加算器 251 に供給される。  
5 また、バリアブルノード計算器 204<sub>p</sub> には、受信用メモリ 205 から受信データ D271 が供給され、その受信データ D271 は、加減算器 252<sub>1</sub> 乃至 252<sub>5</sub> に供給される。

加算器 251 は、全てのメッセージ D251<sub>1</sub> 乃至 D251<sub>5</sub> (メッセージ u<sub>j</sub>) を積算し、9 ビットの積算値 D252 (1 列分のメッセージの総和値 (j = 1 から 5 までの  $\sum u_j$ )) を加減算器 252<sub>1</sub> 乃至 252<sub>5</sub> に供給する。加減算器 252<sub>1</sub> 乃至 252<sub>5</sub> は、加算値 D252 から、メッセージ D251<sub>1</sub> 乃至 D251<sub>5</sub> (メッセージ u<sub>j</sub>) をそれぞれ減算する。即ち、加減算器 252<sub>1</sub> 乃至 252<sub>5</sub> は、全ての枝からのメッセージ u<sub>j</sub> の積算値 D252 から、求めたい枝からのメッセージ D251<sub>1</sub> 乃至 D251<sub>5</sub> (メッセージ u<sub>j</sub>) をそれぞれ減算して、その減算値 (j = 1 から 4 までの  $\sum u_j$ ) を求める。  
15

さらに、加減算器 252<sub>1</sub> 乃至 252<sub>5</sub> は、減算値 (j = 1 から 4 までの  $\sum u_j$ ) に、受信データ D271 (u<sub>0i</sub>) を加算して、6 ビットの加算値 D253<sub>1</sub> 乃至 D253<sub>5</sub> を、バリアブルノード演算の結果として出力する。

以上のように、バリアブルノード計算器 204<sub>p</sub> では、式 (1) の演算が行われ、メッセージ v<sub>i</sub> が求められる。  
20

なお、図 1.4 では、各メッセージが符号ビットを合わせて合計 6 ビットに量子化されているものとして、バリアブルノード計算器 204<sub>p</sub> を表している。また、図 1.4 の回路は 1 つのバリアブルノードに相当する。ここで処理の対象としている図 8 の検査行列については、その列数である 90 列のバリアブルノードが存在するから、図 1.2A 乃至 図 1.2C の復号装置は、図 1.4 に示したような回路を 90 個有している。  
25

ここで、図 1.4 のバリアブルノード計算器 204<sub>p</sub> では、5 個のメッセージを

同時に計算することができる。そして、ここで処理の対象としている図8の検査行列は、重みが5, 3, 2, 1の列が、それぞれ、15列、45列、29列、1列あるので、バリアブルノード計算器204<sub>1</sub>乃至204<sub>90</sub>のうちの15個は、図14の回路と同一構成となっており、残りの45個、29個、1個は、図14の回路と同様の3, 2, 1つのメッセージをそれぞれ同時に計算することができる回路構成となっている。

なお、図示しないが、図12A乃至図12Cの復号装置においても、図9における場合と同様に、復号の最終段においては、式(1)のバリアブルノード演算の代わりに、式(5)の演算が行われ、その演算結果が最終的な復号結果として10出力される。

図12A乃至図12Cの復号装置によれば、269個ある枝に対応するメッセージすべてを1クロックで同時に計算することができる。

図12A乃至図12Cの復号装置を繰り返し用いて復号する場合には、チェックノード演算とバリアブルノード演算とを交互に行い、1回の復号を2クロックで行うことができる。従って、例えば、50回の復号を行うためには、符号長が90個の符号を1フレームとする受信データを受信する間に $2 \times 50 = 100$ クロック動作すれば良いことになり、ほぼ受信周波数と同一の動作周波数でよいことになる。一般的に、LDPC符号は、符号長が数千から数万と大きいことから、図12A乃至図12Cの復号装置を用いれば、復号回数を極めて多くすることができ、誤り訂正性能の向上を期待することができる。

しかしながら、図12A乃至図12Cの復号装置は、タナーグラフのすべての枝に対応するメッセージの演算を、並列で行うため、回路規模が、符号長に比例して大きくなる。また、図12A乃至図12Cの復号装置を、ある符号長の、ある符号化率の、ある検査行列を持つLDPC符号の復号を行う装置として構成した場合、その復号装置において、他の符号長や、他の符号化率、他の検査行列を持つLDPC符号の復号を行うことは困難となる。即ち、図12A乃至図12Cの復号装置は、図9の復号装置のように、制御信号を変えるだけでは、様々な符号を

復号することに対処することが困難であり、符号依存性が高い。

図9および図12A乃至図12Cの復号装置の他に、一つでも全てでもなく、4つずつのメッセージの計算を同時に行う実装法について、例えば、E. Yeo, P. Pakzad, B. Nikolic and V. Anantharam, "VLSI Architectures for iterative Decoders in Magnetic Recording Channels", IEEE Transactions on Magnetics, Vol. 37, No. 2, March 2001に述べられているが、この場合、メモリの異なるアドレスからの同時読み出し、もしくは同時書き込みを避けることが一般的には容易でなく、メモリアクセス制御が困難であるという問題がある。

また、サムプロダクトアルゴリズムを近似して実装する方法なども提案されているが、この方法では、性能の劣化を招いてしまう。サムプロダクトアルゴリズムをハードウェアに実装する場合には、上述したように、枝に対応するメッセージの演算（チェックノード演算とビットノード(bit node)計算）を、1つずつシリアル(serial)に行う方法、すべて並列（フルパラレル(full parallel)）に行う方法、幾つかずつ並列（パラレル(parallel)）に行う方法がある。

しかしながら、枝に対応するメッセージの演算を1つずつ行う方法では、高い動作周波数が必要となる。そこで、スループット(throughput)を上げる方法として、装置を、パイプライン(pipeline)化する方法があるが、この場合、回路規模、特にメモリ（の容量）が大きくなってしまう。

また、メッセージの演算を全て並列に行う方法では、ロジック(logic)の回路規模が大きくなるとともに、符号依存性が高くなる。

さらに、メッセージの演算を、幾つかずつ並列に行う方法では、メモリアクセスの制御が難しくなる。

25

#### 発明の開示

本発明は、このような状況に鑑みてなされたものであり、ロジック、メモリ共

に回路規模を抑制しつつ、動作周波数も十分実現可能な範囲に抑え、メモリアクセスの制御も容易に行うことができるようとするものである。

本発明の復号装置は、 $P \times P$  の単位行列、その単位行列のコンポーネントである 1 のうちの 1 個以上が 0 になった行列である準単位行列、単位行列もしくは準単位行列をサイクリックシフトした行列であるシフト行列、単位行列、準単位行列、もしくはシフト行列のうちの複数の和である和行列、または  $P \times P$  の 0 行列を構成行列として、LDPC 符号の検査行列が、複数の構成行列の組合せで表される場合において、LDPC 符号の復号のための  $P$  個のチェックノードの演算を同時に行う第 1 の演算手段と、LDPC 符号の復号のための  $P$  個のバリアブルノードの演算を同時に第 2 の演算手段とを備えることを特徴とする。  
10

第 1 の演算手段は、チェックノードの演算を行う  $P$  個のチェックノード計算器を有し、第 2 の演算手段は、バリアブルノードの演算を行う  $P$  個のバリアブルノード計算器を有するようにすることができる。

$P$  個のチェックノードの演算、または  $P$  個のバリアブルノードの演算の結果得られる  $P$  個の枝に対応するメッセージデータを同時に読み書きするメッセージ記憶手段をさらに備えるようにすることができる。  
15

メッセージ記憶手段は、チェックノードの演算時に読み出される枝に対応するメッセージデータを、検査行列の 1 を行方向に詰めるように格納するようになることができる。

メッセージ記憶手段は、バリアブルノード演算時に読み出される枝に対応するメッセージデータを、検査行列の 1 を列方向に詰めるように格納するようになることができる。  
20

メッセージ記憶手段は、検査行列を表す構成行列のうちの、重みが 2 以上の構成行列について、その構成行列を、重みが 1 の単位行列、準単位行列、またはシフト行列の和の形で表現したときの、その重みが 1 の単位行列、準単位行列、またはシフト行列に属する  $P$  個の枝に対応するメッセージを、同一のアドレスに格納するようにすることができる。  
25

メッセージ記憶手段は、行数／P 個の FIFO と、列数／P 個の FIFO とで構成され、行数／P 個の FIFO と列数／P 個の FIFO は、それぞれ、検査行列の行と列の重みに対応するワード数を有するようにすることができる。

メッセージ記憶手段は、RAM(Random Access Memory)で構成され、RAM は、

- 5 メッセージデータを、読み出される順番に詰めて格納し、格納位置順に読み出す  
ようにすることができる。

LDPC 符号の受信情報を格納するとともに、P 個の受信情報を同時に読み出す受信情報記憶手段をさらに備えるようにすることができる。

受信情報記憶手段は、受信情報を、バリアブルノードの演算に必要となる順番

- 10 に読み出すことができるように格納するようにすることができる。

P 個のチェックノードの演算、または P 個のバリアブルノードの演算の結果得られるメッセージを並べ替える並べ替え手段をさらに備えるようにすることができる。

並べ替え手段は、バレルシフタで構成されるようにすることができる。

- 15 第 1 の演算手段と第 2 の演算手段は、P 個の枝に対応するメッセージを求める  
ようにすることができる。

第 1 の演算手段は、P 個のチェックノードの演算と P 個のバリアブルノードの演算の一部とを行い、第 2 の演算手段は、P 個のバリアブルノードの演算の他の一部を行うようにすることができる。

- 20 第 1 の演算手段は、P 個のチェックノードの演算と P 個のバリアブルノードの演算の一部を行う P 個の計算器を有し、第 2 の演算手段は、P 個のバリアブルノードの演算の他の一部を行う P 個の計算器を有するようにすることができる。

第 1 の演算手段が P 個のチェックノードの演算と P 個のバリアブルノードの演算の一部を行うことにより得られる P 個の枝に対応する第 1 の復号途中結果  
25 を同時に読み書きする第 1 の復号途中結果記憶手段をさらに備えるようにするこ  
とができる。

第 1 の復号途中記憶手段は、P 個のバリアブルノードの演算の他の一部を行つ

時に読み出される枝に対応する第1の復号途中結果を、検査行列の1を行方向に詰めるように格納するようにすることができる。

第1の復号途中結果記憶手段は、2個のシングルポートRAM(Random Access Memory)であるようにすることができる。

5 2個のシングルポートRAMは、第1の復号途中結果をP個ずつ交互に格納するようにすることができる。

2個のシングルポートRAM(Random Access Memory)は、それぞれ同一のアドレ<sup>ス</sup>に格納している第1の復号途中結果を読み出すようにすることができる。

10 第1の復号途中結果記憶手段は、検査行列を表す構成行列のうちの、重みが2以上<sup>の構成行列について</sup>、その構成行列を、重みが1の単位行列、準単位行列、またはシフト行列の和の形で表現したときの、その重みが1の単位行列、準単位行列、またはシフト行列に属するP個の枝に対応する第1の復号途中結果を、同一のアドレ<sup>ス</sup>に格納するようにすることができる。

15 第2の演算手段がP個のバリアブルノードの演算の他の一部を行うことにより得られるP個の枝に対応する第2の復号途中結果を同時に読み書きする第2の復号途中結果記憶手段をさらに備えるようにすることができる。

LDPC符号の受信情報を格納するとともに、P個の受信情報を同時に読み出す受信情報記憶手段をさらに備えるようにすることができる。

20 受信情報記憶手段は、受信情報を、P個のバリアブルノードの演算の他の一部の演算に必要となる順番に読み出すことができるよう<sup>に</sup>格納するようにすることができる。

25 第1の演算手段がP個のチェックノードの演算とP個のバリアブルノードの演算の一部を行うことにより得られる第1の復号途中結果、または第2の演算手段がP個のバリアブルノードの演算の他の一部を行うことにより得られる第2の復号途中結果を並べ替える並べ替え手段をさらに備えるようにすることができる。

並べ替え手段は、バレルシフタで構成されるようにすることができる。

第1の演算手段は、P個のチェックノードの演算の一部を行い、第2の演算手段は、P個のチェックノードの演算の他の一部と、P個のバリアブルノードの演算とを行うようにすることができる。

第1の演算手段は、P個のチェックノードの演算の一部を行うP個の計算器を  
5 有し、第2の演算手段は、P個のチェックノードの演算の他の一部と、P個のバ  
リアブルノードの演算を行うP個の計算器を有することができる。

第1の演算手段がP個のチェックノードの演算の一部を行うことにより得ら  
れるP個の枝に対応する第1の復号途中結果を同時に読み書きする第1の復号  
途中結果記憶手段をさらに備えるようにすることができる。

10 第2の演算手段がP個のチェックノードの演算の他の一部と、P個のバリアブ  
ルノードの演算を行うことにより得られるP個の枝に対応する第2の復号途中  
結果を同時に読み書きする第2の復号途中結果記憶手段をさらに備えるようす  
ることができる。

第2の復号途中結果記憶手段は、P個のチェックノードの演算の他の一部と、  
15 P個のバリアブルノードの演算を行う時に読み出される枝に対応する第2の復号  
途中結果を、検査行列の1を列方向に詰めるように格納するようにするこ  
ことができる。

第2の復号途中結果記憶手段は、2個のシングルポートRAM(Random Access  
Memory)であるようにすることができる。

20 2個のシングルポートRAMは、第2の復号途中結果をP個ずつ交互に格納す  
るようにすることができる。

2個のシングルポートRAM(Random Access Memory)は、それぞれ同一のア  
ドレスに格納している第2の復号途中結果を読み出すようにすることができる。

25 第2の復号途中結果記憶手段は、検査行列を表す構成行列のうちの、重みが2  
以上の構成行列について、その構成行列を、重みが1の単位行列、準単位行列、  
またはシフト行列の和の形で表現したときの、その重みが1の単位行列、準単位  
行列、またはシフト行列に属するP個の枝に対応する第2の復号途中結果を、

同一のアドレスに格納するようにすることができる。

LDPC 符号の受信情報を格納するとともに、P 個の受信情報を同時に読み出す受信情報記憶手段をさらに備えるようにすることができる。

請求の範囲第 3 6 項に記載の復号装置であって、受信情報記憶手段は、受信情報 5 を、P 個のチェックノードの演算の他の一部と、P 個のバリアブルノードの演算に必要となる順番に読み出すことができるよう格納するようにすることができる。

第 1 の演算手段が P 個のチェックノードの演算の一部を行うことにより得られる第 1 の復号途中結果、または第 2 の演算が P 個のチェックノードの演算の 10 他の一部と、P 個のバリアブルノードの演算を行うことにより得られる第 2 の復号途中結果を並べ替える並べ替え手段をさらに備えるようにすることができる。

並べ替え手段は、バレルシフタで構成されるようにすることができる。

本発明の復号方法は、 $P \times P$  の単位行列、その単位行列のコンポーネントである 15 1 のうちの 1 個以上が 0 になった行列である準単位行列、単位行列もしくは準単位行列をサイクリックシフトした行列であるシフト行列、単位行列、準単位行列、もしくはシフト行列のうちの複数の和である和行列、または  $P \times P$  の 0 行列を構成行列として、LDPC 符号の検査行列が、複数の構成行列の組合せで表される場合において、LDPC 符号の復号のための P 個のチェックノードの演算を同時 20 行う第 1 の演算ステップと、LDPC 符号の復号のための P 個のバリアブルノードの演算を同時に行う第 2 の演算ステップとを含むことを特徴とする。

本発明のプログラムは、LDPC 符号の復号のための P 個のチェックノードの演算を同時に行う第 1 の演算ステップと、LDPC 符号の復号のための P 個のバリアブルノードの演算を同時に行う第 2 の演算ステップとを含むことを特徴とする。

本発明においては、 $P \times P$  の単位行列、その単位行列のコンポーネントである 25 1 のうちの 1 個以上が 0 になった行列である準単位行列、単位行列もしくは準単位行列をサイクリックシフトした行列であるシフト行列、単位行列、準単位行列、もしくはシフト行列のうちの複数の和である和行列、または  $P \times P$  の 0 行列を構

成行列として、LDPC 符号の検査行列が、複数の構成行列の組合せで表される場合において、LDPC 符号の復号のための P 個のチェックノードの演算が同時に行われ、LDPC 符号の復号のための P 個のバリアブルノードの演算が同時に行われる。

5

#### 図面の簡単な説明

図 1 は、LDPC 符号の検査行列 H を説明する図である。

図 2 は、LDPC 符号の復号手順を説明するフローチャートである。

図 3 は、メッセージの流れを説明する図である。

10 図 4 は、LDPC 符号の検査行列の例を示す図である。

図 5 は、検査行列のタナーグラフを示す図である。

図 6 は、バリアブルノードを示す図である。

図 7 は、チェックノードを示す図である。

図 8 は、LDPC 符号の検査行列の例を示す図である。

15 図 9 は、ノード演算を一つずつ行う LDPC 符号の復号装置の構成例を示すブロック図である。

図 10 は、メッセージを一つずつ計算するチェックノード計算器の構成例を示すブロック図である。

20 図 11 は、メッセージを一つずつ計算するバリアブルノード計算器の構成例を示すブロック図である。

図 12 A は、ノード演算を全て同時に行う LDPC 符号の復号装置の構成例を示すブロック図である。

図 12 B は、ノード演算を全て同時に行う LDPC 符号の復号装置の構成例を示すブロック図である。

25 図 12 C は、ノード演算を全て同時に行う LDPC 符号の復号装置の構成例を示すブロック図である。

図 13 は、メッセージを同時に計算するチェックノード計算器の構成例を示す

ブロック図である。

図14は、メッセージを同時に計算するバリアブルノード計算器の構成例を示すブロック図である。

図15は、 $5 \times 5$ 単位に分割した検査行列を示す図である。

5 図16Aは、本発明を適用した復号装置の一実施の形態の構成例を示すプロック図である。

図16Bは、本発明を適用した復号装置の一実施の形態の構成例を示すプロック図である。

10 図16Cは、本発明を適用した復号装置の一実施の形態の構成例を示すプロック図である。

図17は、図16A乃至図16Cの復号装置の復号処理を説明するフローチャートである。

図18は、本発明を適用した復号装置の一実施の形態の構成例を示すプロック図である。

15 図19は、チェックノード計算器の構成例を示すプロック図である。

図20は、バリアブルノード計算器の構成例を示すプロック図である。

図21は、図18の計算器の構成例を示すプロック図である。

図22は、図18の計算器の構成例を示すプロック図である。

20 図23は、図18の復号途中結果格納用メモリの構成例を示すプロック図である。

図24は、図18の復号途中結果格納用RAMの動作を説明するタイミングチャートである。

図25は、図18の復号装置の復号処理を説明するフローチャートである。

25 図26は、本発明を適用した復号装置の一実施の形態の構成例を示すプロック図である。

図27は、チェックノード計算器の構成例を示すプロック図である。

図28は、バリアブルノード計算器の構成例を示すプロック図である。

図29は、図26の計算器の構成例を示すブロック図である。

図30は、図26の計算器の構成例を示すブロック図である。

図31は、図26の復号途中結果格納用メモリの構成例を示すブロック図である。

5 図32は、図31の復号途中結果格納用RAMの動作を説明するタイミングチャートである。

図33は、図26の復号装置の復号処理を説明するフローチャートである。

図34は、本発明を適用したコンピュータの一実施の形態の構成例を示すブロック図である。

10

### 発明を実施するための最良の形態

以下、本発明を適用した具体的な実施の形態について、図面を参照しながら詳細に説明する。

15 図15は、 $5 \times 5$ の行列の単位に間隔を空けた $30 \times 90$ の検査行列の例を示している。なお、図15の検査行列自体は、図8に示した検査行列と同一である。

図15においては、検査行列は、 $5 \times 5$ の単位行列、その単位行列の1のうち1個以上が0になった行列（以下、適宜、準単位行列という）、単位行列または準単位行列をサイクリックシフト(cyclic shift)した行列（以下、適宜、シフト行列という）、単位行列、準単位行列、またはシフト行列のうちの2以上(複数)の和（以下、適宜、和行列という）、 $5 \times 5$ の0行列の組合せで表わされている。なお、図15の検査行列で表現されるLDPC符号は、符号化率2/3、符号長90である。

20 図15の検査行列は、 $5 \times 5$ の単位行列、準単位行列、シフト行列、和行列、0行列で構成されているということができる。そこで、検査行列を構成する、これら5×5の行列を、以下、適宜、構成行列という。

25 図16A乃至図16Cは、図15の検査行列で表現されるLDPC符号を復号する復号装置の一実施の形態の構成例を示している。なお、図16Aは、復号装置

の全体の構成を示している。また、図16Bは、図16Aの復号装置の点線Bで囲まれた図中左部の詳細構成を示し、図16Cは、図16Aの復号装置の点線Cで囲まれた図中右部の詳細構成を示している。

図16A乃至図16Cの復号装置300は、スイッチ310および315、6  
5 つのFIFO311<sub>1</sub>乃至311<sub>6</sub>からなる枝データ格納メモリ311、セレクタ3  
12、5つのチェックノード計算器313<sub>1</sub>乃至313<sub>5</sub>からなるチェックノード  
計算部313、2つのサイクリックシフト回路314および320、18個の  
FIFO316<sub>1</sub>乃至316<sub>18</sub>からなる枝データ格納メモリ316、セレクタ317、  
受信情報を格納する受信データ用メモリ318、パリアブルノード計算部319、  
10 制御部321から構成される。

この復号装置300の各部について詳細に説明する前に、まず、枝データ格納  
メモリ311と316へのデータの格納方法について説明する。

枝データ格納メモリ311は、検査行列の行数30を構成行列の行数5で除算  
した数である6つのFIFO311<sub>1</sub>乃至311<sub>6</sub>から構成されている。FIFO311<sub>1</sub>、  
15 (y=1, 2, . . . , 6) は、構成行列の行数および列数である5つの枝に対  
応するメッセージを同時に読み出しあるは書き込むことができるようになって  
おり、その長さ(段数)は、検査行列の行方向の1の数(ハミング重み)の最大  
数である9になっている。

FIFO311<sub>1</sub>には、図15の検査行列の第1行目から第5行目までの1の位置  
20 に対応するデータが、各行共に横方向(列方向)に詰めた形に(0を無視した形  
で)格納される。すなわち、第j行第i列を、(j, i)と表すこととすると、FIFO  
311<sub>1</sub>の第1の要素(第1段)には、検査行列の(1, 1)から(5, 5)の5×5の單  
位行列の1の位置に対応するデータが格納される。第2の要素には、検査行列の  
構成行列である(1, 21)から(5, 25)のシフト行列(5×5の単位行列を右方向に  
25 3つだけサイクリックシフトしたシフト行列)の1の位置に対応するデータが格  
納される。第3から第8の要素も同様に検査行列の構成行列と対応づけてデータ  
が格納される。そして、第9の要素には、検査行列の(1, 86)から(5, 90)のシフ

ト行列（ $5 \times 5$  の単位行列のうちの 1 行目の 1 を 0 に置き換えて 1 つだけ左にサイクリックシフトしたシフト行列）の 1 の位置に対応するデータが格納される。ここで、検査行列の(1, 86)から(5, 90)のシフト行列においては、1 行目に 1 がないため、FIFO3\_1\_1<sub>1</sub> の 1 行目のみ要素数は 8、残りの行は要素数が 9 となる。

5 FIFO3\_1\_1<sub>2</sub> には、図 15 の検査行列の第 6 行目から第 10 行目までの 1 の位置に対応するデータが格納される。すなわち、FIFO3\_1\_1<sub>2</sub> の第 1 の要素には、検査行列の(6, 1)から(10, 5)の和行列（ $5 \times 5$  の単位行列を右に 1 つだけサイクリックシフトした第 1 のシフト行列と、右に 2 つだけサイクリックシフトした第 2 のシフト行列の和である和行列）を構成する第 1 のシフト行列の 1 の位置に対応するデータが格納される。また、第 2 の要素には、検査行列の(6, 1)から(10, 5)の和行列を構成する第 2 のシフト行列の 1 の位置に対応するデータが格納される。

即ち、重みが 2 以上の構成行列については、その構成行列を、重みが 1 である  $P \times P$  の単位行列、そのコンポーネントである 1 のうち 1 個以上が 0 になった準単位行列、または単位行列もしくは準単位行列をサイクリックシフトしたシフト行列のうちの複数の和の形で表現したときの、その重みが 1 の単位行列、準単位行列、またはシフト行列の 1 の位置に対応するデータ（単位行列、準単位行列、またはシフト行列に属する枝に対応するメッセージ）は、同一アドレス（FIFO3\_1\_1<sub>1</sub> 乃至 3\_1\_1<sub>6</sub> のうちの同一の FIFO）に格納される。

20 以下、第 3 から第 9 の要素についても、検査行列に対応づけてデータが格納される。FIFO3\_1\_1<sub>2</sub> は全行共に要素数は 9 となる。

FIFO3\_1\_1<sub>3</sub> 乃至 3\_1\_1<sub>6</sub> も同様に検査行列に対応づけてデータを格納し、各 FIFO3\_1\_1<sub>3</sub> 乃至 3\_1\_1<sub>6</sub> それぞれの長さは 9 である。

25 枝データ格納メモリ 3\_1\_6 は、検査行列の列数 90 を、構成行列の列数である 5 で割った 18 個の FIFO3\_1\_6<sub>1</sub> 乃至 3\_1\_6<sub>18</sub> から構成されている。FIFO3\_1\_6<sub>x</sub> ( $x = 1, 2, \dots, 18$ ) は、構成行列の行数および列数である 5 つの枝に対応するメッセージを同時に読み出しもしくは書き込むことができるようにな

っている。

FIFO<sub>3 1 6<sub>1</sub></sub>には、図15の検査行列の第1列目から第5列目までの1の位置に対応するデータが、各列共に縦方向（行方向）に詰めた形に（0を無視した形で）格納される。すなわち、FIFO<sub>3 1 6<sub>1</sub></sub>の第1の要素（第1段）には、検査行列の(1, 1)から(5, 5)の $5 \times 5$ の単位行列の1の位置に対応するデータが格納される。  
5 第2の要素には、検査行列の(6, 1)から(10, 5)の和行列（ $5 \times 5$ の単位行列を右に1つだけサイクリックシフトした第1のシフト行列と、右に2つだけサイクリックシフトした第2のシフト行列との和である和行列）を構成する第1のシフト行列の1の位置に対応するデータが格納される。また、第3の要素には、  
10 検査行列の(6, 1)から(10, 5)の和行列を構成する第2のシフト行列の1の位置に対応するデータが格納される。

即ち、重みが2以上の構成行列については、その構成行列を、重みが1である $P \times P$ の単位行列、そのコンポーネントである1のうち1個以上が0になった準単位行列、または単位行列もしくは準単位行列をサイクリックシフトしたシフト行列のうちの複数の和の形で表現したときの、その重みが1の単位行列、準単位行列、またはシフト行列の1の位置に対応するデータ（単位行列、準単位行列、またはシフト行列に属する枝に対応するメッセージ）は、同一アドレス（FIFO<sub>3 1 6<sub>1</sub></sub>乃至<sub>3 1 6<sub>18</sub></sub>のうちの同一の FIFO）に格納される。

以下、第4および第5の要素についても、検査行列に対応づけて、データが格納される。この FIFO<sub>3 1 6<sub>1</sub></sub>の要素数（段数）は、検査行列の第1列から第5列における行方向の1の数（ハミング重み）の最大数である5になっている。

FIFO<sub>3 1 6<sub>2</sub></sub>と<sub>3 1 6<sub>3</sub></sub>も同様に検査行列に対応づけてデータを格納し、それぞれの長さ（段数）は、5である。FIFO<sub>3 1 6<sub>4</sub></sub>乃至<sub>3 1 6<sub>12</sub></sub>も同様に検査行列に対応づけてデータを格納し、それぞれの長さは3である。FIFO<sub>3 1 6<sub>13</sub></sub>乃至<sub>3 1 6<sub>18</sub></sub>も同様に検査行列に対応づけてデータを格納し、それぞれの長さは2である。但し、FIFO<sub>3 1 6<sub>18</sub></sub>の第1の要素は、検査行列の(1, 86)から(5, 90)に相当し、第5列目（検査行列の(1, 90)から(5, 90)）に1がないため、データは格納

されない。

以下、図16A乃至図16Cの復号装置300の各部の動作について詳細に説明する。スイッチ310には、サイクリックシフト回路320から5つのメッセージ（データ）D319が供給されるとともに、制御部321から検査行列のどの行に属するかの情報（Matrixデータ）を表す制御信号D320が供給される。制御信号D320にしたがって、5つのメッセージ（データ）D319を格納する FIFOを、FIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>の中から選択し、選択した FIFOに5つのメッセージデータD319をまとめて順番に供給していく。

枝データ格納メモリ311は、6つのFIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>からなる。枝データ格納メモリ311の FIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>には、スイッチ310から、5つのメッセージD319がまとめて順番に供給され、FIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>は、5つのメッセージD319をまとめて順番に（同時に）格納していく。また、枝データ格納メモリ311は、データを読み出す際には、FIFO<sub>311<sub>1</sub></sub>から5つのメッセージ（データ）D311<sub>1</sub>を順番に読み出し、次段のセレクタ312に供給する。枝データ格納メモリ311は、FIFO<sub>311<sub>1</sub></sub>からのメッセージD311<sub>1</sub>の読み出しの終了後、FIFO<sub>311<sub>2</sub></sub>乃至<sub>311<sub>6</sub></sub>からも、順番に、メッセージD311<sub>1</sub>乃至D311<sub>6</sub>をそれぞれ読み出し、セレクタ312に供給する。

セレクタ312には、制御部321から、FIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>のうち、メッセージデータを読み出す FIFO（現在データが読み出されている FIFO）の選択を表す選択信号D321が供給されるとともに、枝データ格納メモリ311から5つのメッセージ（データ）D311<sub>1</sub>乃至D311<sub>6</sub>が供給される。セレクタ312は、選択信号D321にしたがって、FIFO<sub>311<sub>1</sub></sub>乃至<sub>311<sub>6</sub></sub>のうちの、現在データが読み出されている FIFOを選択し、その選択した FIFOから供給された5つのメッセージデータを、メッセージD312として、チェックノード計算部313に供給する。

チェックノード計算部313は、5つのチェックノード計算器313<sub>1</sub>乃至313<sub>5</sub>からなる。チェックノード計算部313には、セレクタ312を介して5

一つのメッセージ D312 が供給され、そのメッセージ D312 が、チェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> のそれぞれに 1 つずつ供給される。また、チェックノード計算部 313 には、制御部 321 から制御信号 D322 が供給され、その制御信号 D322 が、チェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> に供給される。チェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> は、メッセージ D312 を用いて、式 (7) にしたがって同時に演算を行い、その演算の結果、5 個の枝に対応するメッセージ D313 を求める。チェックノード計算部 313 は、チェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> による演算の結果得られる 5 つのメッセージ D313 をサイクリックシフト回路 314 に供給する。

ここで、制御部 321 からチェックノード計算部 313 に供給される制御信号 D322 は、図 10 の制御信号 D106 に対応するものであり、チェックノード計算部 313<sub>1</sub> 乃至 313<sub>5</sub> それぞれは、図 10 に示したチェックノード計算器 101 と同様に構成される。

サイクリックシフト回路 314 には、チェックノード計算部 313 で計算された 5 つのメッセージ D313 が供給されるとともに、制御部 321 から、そのメッセージ D313 に対応する枝が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D323 が供給される。サイクリックシフト回路 314 は、制御信号 D323 を元に、5 つのメッセージ D313 を並べ替えるサイクリックシフトを行い、その結果をメッセージ D314 として、スイッチ 315 に供給する。

スイッチ 315 には、サイクリックシフト回路 314 から供給される 5 つのメッセージ (データ) D314 が検査行列のどの列に属するかの情報を表す制御信号 D324 が供給されるとともに、サイクリックシフト回路 314 から、メッセージ D314 が供給される。スイッチ 315 は、制御信号 D324 にしたがって、メッセージ D314 を格納する FIFO を、FIFO 316<sub>1</sub> 乃至 316<sub>18</sub> の中から選択し、選択した FIFO に 5 つのメッセージ D314 をまとめて順番に供給していく。

枝データ格納メモリ 316 は、18 個の FIFO 316<sub>1</sub> 乃至 316<sub>18</sub> からなる。

枝データ格納メモリ 316 の FIFO<sub>316<sub>1</sub></sub> 乃至 FIFO<sub>316<sub>18</sub></sub> には、スイッチ 315 から 5 つのメッセージ D314 がまとめて順番に（同時に）供給され、 FIFO<sub>316<sub>1</sub></sub> 乃至 FIFO<sub>316<sub>18</sub></sub> は、その 5 つのメッセージ D314 をまとめて順番に格納していく。また、枝データ格納メモリ 316 は、データを読み出す際には、 FIFO<sub>316<sub>1</sub></sub> から 5 つのメッセージ D315<sub>1</sub> を順番に読み出し、次段のセレクタ 317 に供給する。  
枝データ格納メモリ 316 は、 FIFO<sub>316<sub>1</sub></sub> からのデータの読み出しの終了後、 FIFO<sub>316<sub>2</sub></sub> 乃至 FIFO<sub>316<sub>18</sub></sub> からも、順番に、メッセージ D315<sub>2</sub> 乃至 D31318 を読み出し、セレクタ 317 に供給する。

セレクタ 317 には、制御部 321 から FIFO<sub>316<sub>1</sub></sub> 乃至 FIFO<sub>316<sub>18</sub></sub> のうち、メッセージデータを読み出す FIFO（現在データが読み出されている FIFO）の選択を表す選択信号 D325 が供給されるとともに、枝データ格納メモリ 316 からメッセージデータ D315<sub>1</sub> 乃至 D31318 が供給される。セレクタ 317 は、選択信号 D325 にしたがって、 FIFO<sub>316<sub>1</sub></sub> 乃至 FIFO<sub>316<sub>18</sub></sub> のうちの、現在データが読み出されている FIFO を選択し、その選択した FIFO から供給される 5 つのメッセージデータを、メッセージ D316 として、バリアブルノード計算部 319 と上述した式（5）の演算を行う不図示のブロックに供給する。

一方、受信データ用メモリ 318 は、通信路を通して受信した受信信号から、受信 LLR（対数尤度比）を計算しており、その計算した受信 LLR を 5 つまとめて（同時に）受信データ D317（LDPC 符号）としてバリアブルノード計算部 319 と、式（5）の演算を行う不図示のブロックに供給する。なお、受信データ用メモリ 318 は、バリアブルノード計算部 319 のバリアブルノード演算に必要となる順番に、受信データ D317 を読み出す。

バリアブルノード計算部 319 は、5 つのバリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> からなる。バリアブルノード計算部 319 には、セレクタ 317 を介して 5 つのメッセージ D316 が供給され、そのメッセージ D316 が、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> のそれぞれに 1 つずつ供給される。また、バリアブルノード計算部 319 には、受信データ用メモリ 318 から 5 つの受信デー

タ D317 が供給され、その受信データ D317 が、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> のそれぞれに 1 つずつ供給される。さらに、バリアブルノード計算部 319 には、制御部 321 から制御信号 D326 が供給され、その制御信号 D326 がバリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> に供給される。

5 バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> は、メッセージ D316 と、受信データ D317 を用いて、式（1）にしたがって同時に演算を行い、その演算の結果、5 個の枝に対応するメッセージ D318 を求める。バリアブルノード計算部 319 は、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> の結果得られる 5 つのメッセージ D318 を、サイクリックシフト回路 320 に供給する。

10 ここで、制御部 521 からバリアブルノード計算部 319 に供給される制御信号 D326 は、図 11 の制御信号 D107 に対応するものであり、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> それぞれは、図 11 のバリアブルノード計算器 103 と同様に構成される。

15 サイクリックシフト回路 320 には、バリアブルノード計算部 319 から 5 つのメッセージ D318 が供給されるとともに、制御部 321 から、そのメッセージ D318 に対応する枝が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報を表す制御信号 D327 が供給される。サイクリックシフト回路 320 は、制御信号 D327 を元に、メッセージ D327 を並べ替えるサイクリックシフトを行い、その結果をメッセージ D319 として、スイッチ 3  
20 10 に供給する。

なお、制御部 321 は、制御信号 D320 をスイッチ 310 に、選択信号 D321 をセレクタ 312 に供給することにより、それぞれを制御する。また制御部 321 は、制御信号 D322 をチェックノード計算部 313 に、制御信号 D323 をサイクリックシフト回路 314 に、制御信号 D324 をスイッチ 315 に供給することにより、それを制御する。さらに、制御部 321 は、選択信号 D325 をセレクタ 317、制御信号 D326 をバリアブルノード計算部 319 に、制御信号 D327 をサイクリックシフト回路 320 に供給することにより、それを制御する。

以上の動作を1巡することで、LDPC符号の1回の復号を行うことができる。

図16A乃至図16Cの復号装置300は、所定の回数だけLDPC符号を復号した後、図示しないが、式(5)にしたがって最終的な復号結果を求めて出力する。

なお、枝データ（枝に対応するメッセージ）が欠けている箇所に関しては、メモリ格納時（枝データ格納メモリ311と316へのデータ格納時）には、何のメッセージも格納せず、また、ノード演算時（チェックノード計算部313でのチェックノード演算時とバリアブルノード計算部319でのバリアブルノード演算時）にも何の演算も行わない。

図17は、図16A乃至図16Cの復号装置300の復号処理を説明するフローチャートである。この処理は、例えば、受信データ用メモリ318に復号すべき受信データが格納されたとき、開始される。

ステップS31において、バリアブルノード計算部319は、バリアブルノード演算を行う。

具体的には、バリアブルノード計算部319には、セレクタ317を通して、5つのメッセージD316（メッセージ $u_j$ ）が供給される。即ち、枝データ格納メモリ316は、後述するステップS39で格納されたFIFO $316_1$ から5つのメッセージ $D316_1$ を順番に読み出し、その後、FIFO $316_2$ 乃至 $316_{18}$ からも、順番に、メッセージ $D316_2$ 乃至 $D316_{18}$ を読み出して、セレクタ317に供給する。

セレクタ317には、制御部321からFIFO $316_1$ 乃至 $316_{18}$ のうち、メッセージ（データ）を読み出す FIFO（現在データが読み出されている FIFO）の選択を表す選択信号D307が供給されるとともに、枝データ格納メモリ316からメッセージデータ $D316_1$ 乃至 $D316_{18}$ が供給される。セレクタ317は、選択信号D307にしたがって、FIFO $316_1$ 乃至 $316_{18}$ のうちの、現在データが読み出されている FIFOを選択し、その選択した FIFOから供給される5つのメッセージデータを、メッセージD316として、バリアブルノード計算部319に供給する。

なお、受信データ用メモリ306から供給された受信データD309に対して、

まだチェックノード演算が行われておらず、枝データ格納メモリ 316 にメッセージ D304 が格納されていない場合、バリアブルノード計算部 319 は、バリアブルノード演算に用いるメッセージ  $u_j$  を初期値に設定する。

また、バリアブルノード計算部 319 には、受信データ用メモリ 318 から 5 つの受信データ D309 (受信値  $u_{0i}$ ) が供給され、その受信データ D309 が、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> のそれぞれに 1 つずつ供給される。さらに、バリアブルノード計算部 319 には、制御部 321 から制御信号 D315 が供給され、その制御信号 D315 がバリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> に供給される。

10 バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> は、メッセージ D316 と、受信データ D309 を用いて、制御信号 D315 に基づいて、式 (1) にしたがって同時に演算を行い、その演算の結果 5 つのメッセージ D319 を求める。

即ち、制御部 321 がバリアブルノード計算部 319 に供給する制御信号 D315 は、前述の図 11 で説明した制御信号 D107 に対応するものであり、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> は、制御信号 D309 にしたがい、セレクタ 317 を介して、枝データ格納メモリ 316 から必要なメッセージ D314 (D316) を、それぞれ 1 つずつ読み出すとともに、受信データ用メモリ 318 から供給された 5 つの受信データ D309 を、それぞれ 1 つずつ読み出して、バリアブルノード演算を行い、その演算の結果 5 つのメッセージ D319 を同時に求め 20 る。

ステップ S31 の処理後は、ステップ S32 に進み、バリアブルノード計算部 319 は、バリアブルノード計算器 319<sub>1</sub> 乃至 319<sub>5</sub> のバリアブルノード演算の結果得られる 5 つのメッセージ D319 (メッセージ  $v_i$ ) をサイクリックシフト回路 320 に供給し、ステップ S33 に進む。

25 ステップ S33において、サイクリックシフト回路 320 は、バリアブルノード計算部 319 から供給された 5 つのメッセージ D318 を、サイクリックシフトする (並べ替える)。

具体的には、サイクリックシフト回路 320 には、バリアブルノード計算部 319 からメッセージ D318 が供給されるとともに、制御部 321 から、そのメッセージ D318 に対応する枝が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D327 が供給される。サイクリックシフト回路 320 は、制御信号 D327 を元に、5 つのメッセージ D327 をサイクリックシフトし、その結果をメッセージ D319 として、スイッチ 310 に供給する。

ステップ S33 の処理後は、ステップ S34 に進み、スイッチ 310 は、サイクリックシフト回路 320 から供給される 5 つのメッセージ D319 を枝データ格納メモリ 311 に供給する。

具体的には、スイッチ 310 には、サイクリックシフト回路 320 からメッセージ (データ) D304 が供給されるとともに、そのメッセージ D304 が検査行列のどの行に属するかの情報を表す制御信号 D312 が供給される。スイッチ 310 は、制御信号 D312 にしたがって、メッセージ D304 を格納する FIFO を、枝データ格納メモリ 311 の FIFO<sub>300<sub>1</sub></sub> 乃至 FIFO<sub>300<sub>6</sub></sub> の中から選択し、選択した FIFO に 5 つのメッセージデータ D304 をまとめて順番に供給していく。

そして、枝データ格納メモリ 311 の FIFO<sub>300<sub>1</sub></sub> 乃至 FIFO<sub>300<sub>18</sub></sub> は、スイッチ 310 から供給された 5 つのメッセージデータ D304 をまとめて順番に格納していく。

ステップ S34 の処理後は、ステップ S35 に進み、制御部 321 は、バリアブルノード計算部 319 により、全枝数のメッセージが演算されたかどうかを判定し、全枝数のメッセージが演算されていないと判定した場合、ステップ S31 に戻り、上述した処理を繰り返す。

一方、ステップ S35において、バリアブルノード計算部 319 は、全枝数のメッセージが演算されたと判定した場合、ステップ S36 に進み、チェックノード計算部 313 は、チェックノード演算を行う。

具体的には、チェックノード計算部 313 には、セレクタ 312 を介して、5

つのメッセージ D302 が供給される。即ち、枝データ格納メモリ 311 は、ステップ S34 で格納された FIFO 311<sub>1</sub> から 5 つのメッセージ D311<sub>1</sub> (メッセージ v<sub>i</sub>) を順番に読み出し、その後、FIFO 311<sub>2</sub> 乃至 311<sub>6</sub> からも、順番に、メッセージデータ D311<sub>2</sub> 乃至 D311<sub>6</sub> を読み出し、セレクタ 312 に供給する。

- 5 セレクタ 312 には、制御部 321 から FIFO 311<sub>1</sub> 乃至 311<sub>6</sub> のうち、メッセージデータを読み出す FIFO (現在データが読み出されている FIFO) の選択を表す選択信号 D321 が供給されるとともに、枝データ格納メモリ 311 からメッセージデータ D311<sub>1</sub> 乃至 D311<sub>6</sub> が供給される。セレクタ 301 は、選択信号 D321 にしたがって、FIFO 311<sub>1</sub> 乃至 311<sub>6</sub> のうちの、現在データが読み出されている FIFO を選択し、その選択した FIFO から供給される 5 つのメッセージデータを、メッセージ D311 として、チェックノード計算部 313 に供給する。

- また、チェックノード計算部 313 には、制御部 321 から制御信号 D322 が供給される。チェックノード計算部 313 のチェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> は、制御信号 D322 に基づいて、メッセージ D302 を用いて、上述した式 15 (7) にしたがって同時にチェックノード演算を行い、その演算結果である 5 つのメッセージ D303 (メッセージ u<sub>j</sub>) を求める。

- 即ち、制御部 321 がチェックノード計算部 313 に供給する制御信号 D322 は、前述の図 10 で説明した制御信号 D106 に対応するものであり、チェックノード計算器 313<sub>1</sub> 乃至 313<sub>5</sub> は、制御信号 D322 にしたがい、セレクタ 312 を介して、枝データ格納メモリ 311 から必要なメッセージ D311 (D312) を、それぞれ 1 つずつ読み出しながら、チェックノード演算を行い、その演算の結果 5 つのメッセージ D313 を同時に求める。

- ステップ S37 の処理後は、ステップ S38 に進み、チェックノード計算部 313 は、チェックノードの演算の結果得られる 5 つのメッセージ D313 をサイクリックシフト回路 314 に出力して、ステップ S38 に進む。

ステップ S38において、サイクリックシフト回路 314 は、チェックノード計算部 313 から供給された 5 つのメッセージ D313 を、サイクリックシフトす

る。

具体的には、サイクリックシフト回路 314 には、チェックノード計算部 313 からメッセージ D313 が供給されるとともに、制御部 321 から、そのメッセージ D313 に対応する枝が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D314 が供給される。サイクリックシフト回路 314 は、制御信号 D314 を元に、5 つのメッセージ D313 をサイクリックシフトし、その結果をメッセージ D304 として、スイッチ 315 に供給する。

ステップ S38 の処理後は、ステップ S39 に進み、スイッチ 315 は、サイクリックシフト回路 314 から供給される 5 つのメッセージ D304 を枝データ格納メモリ 316 に格納する。

具体的には、スイッチ 316 には、サイクリックシフト回路 314 から、5 つのメッセージ (データ) D304 が供給されるとともに、そのメッセージ (データ) D304 が検査行列のどの列に属するかの情報を表す制御信号 D324 が供給される。スイッチ 316 は、制御信号 D324 にしたがって、メッセージ D304 を格納する FIFO を、枝データ格納メモリ 316 の FIFO 316<sub>1</sub> 乃至 316<sub>18</sub> の中から選び、選んだ FIFO に 5 つのメッセージデータ D304 をまとめて順番に供給していく。

そして、枝データ格納メモリ 316 の FIFO 316<sub>1</sub> 乃至 316<sub>18</sub> は、スイッチ 316 から供給された 5 つのメッセージデータ D304 をまとめて順番に格納していく。

ステップ S39 の処理後は、ステップ S40 に進み、制御部 321 は、チェックノード計算部 313 により、全枝数のメッセージが演算されたかどうかを判定し、全枝数のメッセージが演算されていないと判定した場合、ステップ S36 に戻り、上述した処理を繰り返す。

一方、ステップ S40 において、制御部 321 は、チェックノード計算部 313 により、全枝数のメッセージが演算されたと判定した場合、処理を終了する。

なお、復号装置 300 は、復号回数だけ図 17 の復号処理を繰り返し行ない、チェックノード計算部 313 が、最後のチェックノード演算を行った場合、チェックノード演算の結果得られるメッセージ D304 が、枝データ格納メモリ 316 から、セレクタ 317 を介して、上述した式（5）の演算を行う不図示のブロックに供給される。不図示のブロックには、さらに受信データ用メモリ 306 から受信データ D309 が供給され、不図示のブロックは、メッセージ D304 と受信データ D309 を用いて、式（5）の演算を行い、その演算結果を最終的な復号結果として出力する。

上記説明には、枝データ格納に FIFO を用いたが（枝データ格納メモリ 311 と 316 を FIFO で構成するようにしたが）、FIFO の代わりに RAM を用いても構わない。その場合、RAM には、P 個の枝情報（枝に対応するメッセージ）を同時に読み出すことの出来るビット幅と、枝総数/P のワード(word)数が必要となる。さらに、RAM への書き込みは、検査行列の情報から、書き込もうとしているデータが次に読み出される際に何番目に読み出されるかを求め、その位置に書き込む。また、RAM からの読み出しの際には、アドレスの先頭から順次データを読み出す。即ち、RAM は、メッセージデータを読み出される順番に詰めて格納し、格納位置順に読み出す。FIFO の代わりに RAM を用いると、セレクタ 312 および 317 は不要になる。

なお、FIFO や RAM の物理的なビット幅が足りない場合には、複数の RAM を用いて同じ制御信号を与えることで、論理的に 1 つの RAM とみなすことができる。

ところで、図 16A 乃至図 16C の復号装置 300 では、チェックノード演算の結果得られるメッセージ  $u_j$  を用いて、バリアブルノード演算が行われ、その演算の結果得られるメッセージ  $v_i$  を用いて、チェックノード演算が行われるため、チェックノード演算の結果得られる枝に対応するメッセージ  $u_j$  とバリアブルノード演算の結果得られる枝に対応するメッセージ  $v_i$  をすべて格納する枝データ格納メモリ 311 と枝データ格納メモリ 316 が必要である。即ち、復号装置では、検査行列 H の “1” の数の 2 倍のメッセージを格納するために必要な

容量のメモリが必要である。

そこで、復号装置の回路規模さらに小さくするため、図16A乃至図16Cの復号装置300に比べて、さらにメモリの容量を減らした復号装置を以下に示す。

図18は、本発明を適用した図15の検査行列で表現されるLDPC符号を復号する復号装置の他の一実施の形態の構成例を示すブロック図である。

図18の復号装置400では、図16Aと図16Bの枝データ格納メモリ311が、枝データ格納メモリ311に比べて容量の小さい復号途中結果格納用メモリ410になっている。

復号装置400は、復号途中結果格納用メモリ410、サイクリックシフト回路411、5つの計算器412<sub>1</sub>乃至計算器412<sub>5</sub>からなる計算部412、復号途中結果格納用メモリ413、サイクリックシフト回路414、5つの計算器415<sub>1</sub>乃至計算器415<sub>5</sub>からなる計算部415、受信用メモリ416、および制御部417から構成される。

ここで、図19乃至図22を用いて、図18の計算部412の計算器412<sub>1</sub>乃至計算器412<sub>5</sub>、および計算部415の計算器415<sub>1</sub>乃至計算器415<sub>5</sub>と図10のチェックノード計算器101と図11のバリアブルノード計算器103との関係について説明する。

図19と図20は、前述の図10のチェックノード計算器101と図11のバリアブルノード計算器103とそれ同一の図である。また、図21は、計算部412<sub>k</sub> (k=1, 2, ..., 5) の構成例を示しており、図22は、計算部415<sub>k</sub> (k=1, 2, ..., 5) の構成例を示している。

図18の復号装置400では、計算器412<sub>k</sub>がチェックノード演算を行い、計算部415<sub>k</sub>が、バリアブルノード演算をおこなうのではなく、計算器412<sub>k</sub>がチェックノード演算とバリアブルノード演算の一部を、計算器415<sub>k</sub>がバリアブルノード演算の他の一部を行う。

即ち、図21の計算器412<sub>k</sub>は、ブロックA' とブロックB' から構成されている。ブロックA' は、図19のチェックノード計算器101のチェックノード

演算を行うブロック A と同様に構成されている。また、ブロック B' は、図 20 のバリアブルノード計算器 10.3 の一部である、検査行列の各列の全ての枝に対応するメッセージ  $u_j$  の積算値から、求めたい枝に対応するメッセージ  $u_j$  を減算するブロック B と同様に構成されている。一方、図 22 の計算器 415<sub>k</sub> は、ブロッC C' から構成されている。ブロック C' は、図 20 のバリアブルノード計算器 10.3 の他の一部である、検査行列の各列の枝に対応するメッセージ  $u_j$  を積算し、その積算値に受信値  $u_{0i}$  を加算するブロック C と同様に構成されている。

そして、図 21 の計算器 412<sub>k</sub> は、ブロック A とブロック B による演算の結果、即ち、チェックノード演算とバリアブルノード演算の一部を行った復号途中結果  $u_j$  を復号途中結果格納用メモリ 413 に供給し、図 22 の計算器 415<sub>k</sub> は、バリアブルノード演算の他の一部を行った復号途中結果  $v$  を復号途中結果格納用メモリ 410 に供給する。

従って、図 18 の復号装置 400 は、計算器 412<sub>k</sub> の演算と計算器 415<sub>k</sub> の演算とを交互に行うことにより、チェックノード演算とバリアブルノード演算を行い、復号を行うことができる。

なお、図 22 の計算器 412<sub>k</sub> では、復号途中結果格納用メモリ 413 に格納されている求めたい枝に対応する復号途中結果  $u_j$  を用いて、ブロック B で、計算器 415<sub>k</sub> の演算の結果得られる復号途中結果  $v$  から、求めたい枝に対応する復号途中結果  $u_j$  を減算するので、図 20 の FIFO メモリ 155 が必要ない。

次に、計算器 412<sub>k</sub> で行われる演算と、計算器 415<sub>k</sub> で行われる演算について、式を用いて説明する。

具体的には、計算部 412 は、上述した式 (7) と、以下に表す式 (8) にしたがう第 1 の演算を行い、その第 1 の演算の結果である復号途中結果  $u_j$  を復号途中結果格納用メモリ 410 に供給して格納させる。計算部 415 は、上述した式 (5) にしたがう第 2 の演算を行い、その第 2 の演算の結果である復号途中結果  $v$  を復号途中結果格納用メモリ 410 に供給して格納させる。

$$v_i = v - u_{di} \quad \dots (8)$$

なお、式(8)の $u_{dv}$ は、検査行列Hのi列のメッセージを求めようとする枝からのチェックノード演算の途中結果（ここでは、チェックノード演算結果そのもの）を表している。即ち、 $u_{dv}$ は、求めたい枝に対応する復号途中結果である。

即ち、上述した式(5)にしたがう第2の演算の結果得られる復号途中結果v

- 5 は、受信値 $u_{0i}$ と検査行列Hのi列の各行の1に対応するすべての枝からのチェックノード演算の復号途中結果 $u_j$ とを加算したものであるので、上述した式(7)に用いられる値 $v_i$ は、式(5)にしたがう第2の演算の結果得られる復号途中結果vから、検査行列Hのi列の、各行の1に対応する枝からのチェックノード演算の復号途中結果 $u_j$ のうち、メッセージを求めようとする枝からの10 チェックノード演算の復号途中結果 $u_{dv}$ を引いた値となる。つまり、式(7)の演算に用いられる値 $v_i$ を求める式(1)の演算は、上述した式(5)と式(8)を組み合わせた演算である。

従って、復号装置400では、計算部412による式(7)および式(8)にしたがう第1の演算と、計算部415による式(5)にしたがう第2の演算とが15 交互に行われ、計算部415が、最後の第2の演算の結果を復号結果として出力することにより、LDPC符号の繰り返し復号を行うことができる。

なお、ここでは、式(7)と式(8)にしたがう第1の演算結果を、復号途中結果 $u_j$ を復号途中結果 $u_j$ と記載するが、この復号途中結果 $u_j$ は、式(7)のチェックノード演算結果 $u_j$ に等しい。

- 20 また、第2の演算により求められる式(5)のvは、式(1)のバリアブルノード演算結果 $v_i$ に対して、メッセージを求めようとする枝からのチェックノード演算結果 $u_j$ を加算したものであるから、検査行列Hの1列（1つのバリアブルノード）に対して、1つだけ求められる。

復号装置400では、計算部412が、計算部415による第2の演算の結果25 である検査行列Hの列に対応する復号途中結果v（第2の復号途中結果）を用いて、第1の演算を行い、その演算の結果得られる検査行列Hのi列の、各行の1に対応する枝のメッセージ（各チェックノードが各枝に出力するメッセージ）

の枝からのチェックノード演算の復号途中結果  $u_j$  (第 1 の復号途中結果) を復号途中結果格納用メモリ 413 に格納する。従って、復号途中結果格納用メモリ 413 の容量は、チェックノード演算の結果を格納する図 16 A と C の枝データ格納メモリ 316 と同様に、検査行列の 1 の数 (全枝数) とメッセージの量子化ビット数とを乗算した値となる。一方、計算部 415 は、計算部 412 による第 5 の演算の結果である検査行列 H の i 列の、各行の “1” に対応する復号途中結果  $u_j$  と受信値  $u_{0i}$  を用いて、第 2 の演算を行い、その演算の結果得られる i 列 10 に対応する復号途中結果 v を復号途中結果格納用メモリ 410 に格納する。従って、復号途中結果格納用メモリ 410 に必要な容量は、検査行列の “1” の数より少ない検査行列の列数、即ち、LDPC 符号の符号長と復号途中結果 v の量子化ビット数とを乗算した値となる。

従って、検査行列 H における 1 が疎らな LDPC 符号を復号する復号装置 400 では、図 16 A と B の枝データ格納メモリ 311 に比べて、復号途中結果格納用メモリ 410 のメモリの容量を削減することができ、これにより、復号装置 400 15 の回路規模を小さくすることができる。

さらに、復号装置 400 では、計算部 415 が、式 (5) にしたがう第 2 の演算を行うので、復号装置 400 は、図 16 A 乃至 図 16 C の復号装置 300 において最終的な復号結果を演算する式 (5) の演算を行う不図示のブロックを有する必要がなく、図 16 A 乃至 図 16 C の復号装置 300 に比べて、図 18 の復号 20 装置の回路規模を小さくすることができる。

以下、図 18 の復号装置 400 の各部の動作について詳細に説明する。

復号途中結果格納用メモリ 410 には、計算部 415 から、計算部 415 による第 2 の演算の結果である検査行列の 5 つの列に対応する 5 つの復号途中結果 D415 が供給され、復号途中結果格納用メモリ 410 は、計算部 415 から供給 25 された 5 つの復号途中結果 D415 を、第 1 アドレスから順に格納 (記憶) する。

即ち、復号途中結果格納用メモリ 410 の第 1 アドレスには、検査行列の列に 20 対応する復号途中結果のうち、第 1 列目から第 5 列目の復号途中結果 v が格納

される。そして、同様に、第2アドレスには、第6列目から第10列目の復号途中結果  $v$  が格納され、第3アドレスには、第11列目から第15列目の復号途中結果が格納される。以後、同様に、第16列目から第90列目までの復号途中結果  $v$  が、5個ずつ、第4アドレスから第18アドレスまで格納され、計90個の復号途中結果  $v$  が復号途中結果格納用メモリ410に格納される。従って、復号途中結果格納用メモリ410のワード(word)数は、図15の検査行列  $H$  の列数(LDPC符号の符号長)である90を、同時に読み書きする復号途中結果の数である5で割り算した18となる。

また、復号途中結果格納用メモリ410は、既に格納してある復号途中結果 D415 から、後段の計算部412が求めようとする復号途中結果  $u_j$  の対応する検査行列  $H$  の行において“1”になっている復号途中結果  $v$  を5つ同時に読み出し、復号途中結果 D410 として、サイクリックシフト回路411に供給する。

なお、復号途中結果格納用メモリ410は、例えば、5つの復号途中結果を同時に読み書き可能なシングルポートRAMで構成される。また、復号途中結果格納用メモリ410には、計算部415の第2の演算により演算された列に対応する復号途中結果  $v$  が格納されるので、復号途中結果格納用メモリ410に格納されるデータ量、即ち、復号途中結果格納用メモリ410に必要とされる記憶容量は、復号途中結果の量子化ビット数と、検査行列  $H$  の列数(LDPC符号の符号長)との乗算値である。

サイクリックシフト回路411には、復号途中結果格納用メモリ410から5つの復号途中結果 D410 が供給されるとともに、制御部417から、その復号途中結果 D410 に対応する検査行列の1が、検査行列において元となる単位行列などを幾つサイクリックシフトであるかの情報(Matrixデータ)を表す制御信号 D619 が供給される。サイクリックシフト回路611は、制御信号 D619 を元に、5つの復号結果 D410 を並べ替えるサイクリックシフトを行い、その結果を復号途中結果 D411 として、計算部412に供給する。

計算部412は、5つの計算器412<sub>1</sub>乃至412<sub>5</sub>からなる。計算部412に

は、サイクリックシフト回路 411 から、計算部 415 による第 2 の演算の結果得られた 5 つの復号途中結果 D411（第 2 の復号途中結果） $v$  が供給されるとともに、復号途中結果格納用メモリ 413 から、前回、計算器 412<sub>1</sub> 乃至 412<sub>5</sub> による第 1 の演算の結果得られた 5 つの復号途中結果 D413（第 1 の復号途中結果） $u_j$  が供給され、その 5 つの復号途中結果 D411 と 5 つの復号途中結果 D413 が、計算器 412<sub>1</sub> 乃至 412<sub>5</sub> にそれぞれ供給される。また、計算部 412 には、制御部 417 から制御信号 D419 が供給され、その制御信号 D419 が、計算器 412<sub>1</sub> 乃至 412<sub>5</sub> に供給される。なお、制御信号 D419 は、5 つの計算器 412<sub>1</sub> 乃至 412<sub>5</sub> に共通の信号である。

10 計算器 412<sub>1</sub> 乃至 412<sub>5</sub> は、それぞれ復号途中結果 D411 と復号途中結果 D413 を用いて、式（7）と式（8）にしたがって第 1 の演算を行い、復号途中結果 D412（ $v_i$ ）を求める。計算部 412 は、計算器 412<sub>1</sub> 乃至 412<sub>5</sub> による演算の結果得られる検査行列の 5 つの 1 に対応する 5 つの復号途中結果 D412 を復号途中結果格納用メモリ 413 に供給する。

15 復号途中結果格納用メモリ 413 は、例えば、5 つの復号途中結果を同時に読み書き可能な、2 つのシングルポート RAM から構成される。復号途中結果格納用メモリ 413 には、計算部 412 から 5 つの復号途中結果 D412 が供給されるとともに、制御部 417 から復号途中結果 413 の読み書きを制御する制御信号 D420 が供給される。

20 復号途中結果格納用メモリ 413 は、制御信号 D420 に基づいて、計算部 412 から供給される 5 つの復号途中結果 D412 をまとめて格納すると同時に、既に格納してある 5 つの復号途中結果 D412 を読み出し、復号途中結果 D413 として、計算部 412 とサイクリックシフト回路 414 に供給する。即ち、復号途中結果格納用メモリ 413 は、計算部 412 とサイクリックシフト回路 414 に供給する復号途中結果 D413 の読み出しと、計算部 412 から供給される復号途中結果 D412 の書き込みとを、同時に行う。

なお、復号途中結果格納用メモリ 413 には、計算部 412 の第 1 の演算によ

り演算された検査行列  $H$  の  $i$  列の、各行の 1 に対応する枝からのチェックノード演算の復号途中結果  $u_j$  が格納されるので、復号途中結果格納用メモリ 413 に格納されるデータ量、即ち、復号途中結果格納用メモリ 413 に必要とされる記憶容量は、復号途中結果の量子化ビット数と、検査行列の 1 の数との乗算値と  
5 なる。

サイクリックシフト回路 414 には、復号途中結果格納用メモリ 413 から 5 つの復号途中結果 D413（復号途中結果  $u_j$ ）が供給されるとともに、制御部 417 から、その復号途中結果 D413 に対応する検査行列の 1 が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報  
10 (Matrix データ) を表す制御信号 D421 が供給される。サイクリックシフト回路 414 は、制御信号 D421 を元に、5 つの復号途中結果 D413 を並べ替えるサイクリックシフトを行い、その結果を復号途中結果 D414 として、計算部 415 に供給する。

計算部 415 は、5 つの計算器 415<sub>1</sub> 乃至 415<sub>5</sub> からなる。計算部 415 には、サイクリックシフト回路 414 から 5 つの復号途中結果 D414 が供給され、その復号途中結果 D414 が、計算器 415<sub>1</sub> 乃至 415<sub>5</sub> のそれぞれに供給される。また、計算部 415 には、受信用メモリ 417 から 5 つの受信データ D417 (LDPC 符号) が供給され、その受信データ D417 が、計算器 415<sub>1</sub> 乃至 415<sub>5</sub> のそれぞれに供給される。さらに、計算部 417 には、制御部 417 から制御信号 D422 が供給され、その制御信号 D422 が計算器 415<sub>1</sub> 乃至 415<sub>5</sub> に供給される。なお、制御信号 D422 は、5 つの計算器 417<sub>1</sub> 乃至 417<sub>5</sub> に共通の信号  
20 である。

計算器 415<sub>1</sub> 乃至 415<sub>5</sub> は、それぞれ復号途中結果 D414 と受信データ D417 を用いて、式 (5) にしたがって、それぞれ第 2 の演算を行い、復号途中結果 D415 を求める。計算部 415 は、計算器 415<sub>1</sub> 乃至 415<sub>5</sub> の第 2 の演算の結果得られる 5 つの復号途中結果 D415(v) を、復号途中結果格納用メモリ 410 に供給する。また、計算部 415 は、いま行う演算が最後の第 2 の演算である場合、

その演算の結果得られる 5 つの復号途中結果 D415 を、最終的な復号結果として出力する。

受信用メモリ 416 は、通信路を通して受信した受信値（符号ビット）D416 から計算した符号ビットの 0 らしさの値である受信 LLR（対数尤度比）を、受信

5 データ D417 として格納する。

即ち、受信用メモリ 416 の第 1 のアドレスには、検査行列の列に対応する受信データ D417 のうち、検査行列の第 1 列目から第 5 列目までに対応する受信データ D417 が格納される。そして、第 2 のアドレスには、検査行列の第 6 列目から第 10 列目までに対応する受信データ D417 が格納され、第 3 アドレスには、

10 検査行列の第 11 列目から第 16 列目までに対応する受信データ D417 が格納される。以後、同様に、第 4 アドレスから第 18 アドレスまでに、検査行列の第 17 列目から第 90 列目までに対応する受信データ D417 が、5 つずつ格納される。

そして、受信用メモリ 616 は、既に格納している受信データ D417 を、バリアブルノード演算に必要となる順番に 5 つずつ読み出し、計算部 415 に供給する。

なお、受信用メモリ 416 は、例えば、5 つの受信データを同時に読み書き可能なシングルポート RAM から構成される。また、受信用メモリ 416 に格納されるデータ量、即ち、受信用メモリ 315 に必要とされる記憶容量は、LDPC 符号の符号長と、受信データの量子化ビット数との乗算値である。さらに、受信用メモリ 416 のワード（word）数は、LDPC 符号の符号長、即ち、検査行列の列数である 90 を、同時に読み出す受信データ D417 の数である 5 で割り算した値の 18 である。

制御部 417 は、制御信号 D418 をサイクリックシフト回路 411 に、制御信号 D419 を計算部 412 に供給することにより、それぞれを制御する。また、制御部 417 は、制御信号 D420 を復号途中結果格納用メモリ 413 に、制御信号 D421 をサイクリックシフト回路 414 に、制御信号 D421 を計算部 415 にそれぞれ供給することにより、それぞれを制御する。

復号途中結果格納用メモリ 410、サイクリックシフト回路 411、計算部 412、復号途中結果格納用メモリ 413、サイクリックシフト回路 414、計算部 415 の順で、データが一巡することで、復号装置 400 は、1 回の復号を行うことができる。復号装置 400 では、所定の回数だけ繰り返して復号が行われた後、計算部 415 による第 2 の演算の結果である復号途中結果 D415 が、最終的な復号結果として出力される。

図 21 は、図 18 の計算部 412 の計算器 412<sub>1</sub> の構成例を示すブロック図である。

なお、図 21 では、計算器 412<sub>1</sub> について説明するが、計算器 412<sub>2</sub> 乃至計算器 412<sub>5</sub> も同様に構成される。

また、図 21 では、前回の計算部 412 による第 1 の演算の結果得られる各復号途中結果 ( $u_{dv}$ ) が符号ビットを合わせて合計 6 ビット (bit) に量子化され、計算器 415 による第 2 の演算の結果得られる各復号途中結果 (v) が 9 ビットに量子化されているものとして、計算器 412<sub>1</sub> を表している。さらに、図 21 の計算器 412<sub>1</sub> には、クロック c<sub>k</sub> が供給され、このクロック c<sub>k</sub> は、必要なブロックに供給されるようになっている。そして、各ブロックは、クロック c<sub>k</sub> に同期して処理を行う。

図 21 の計算器 412<sub>1</sub> は、制御部 417 から供給される制御信号 D419 に基づいて、復号途中結果格納用メモリ 413 から 1 つずつ読み込まれる、前回の計算部 412 による第 1 の演算の結果得られた復号途中結果 D413 ( $u_{dv}$ ) と、サイクリックシフト回路 411 から 1 つずつ読み込まれる復号途中結果 D411 (v) を用いて、式 (7) と式 (8) にしたがう第 1 の演算を行う。

即ち、計算器 412<sub>1</sub> には、サイクリックシフト回路 411 から供給される 5 つの 9 ビットの復号途中結果 D411 (v) のうちの、1 つの復号途中結果 D411 が供給されるとともに、復号途中結果格納用メモリ 413 から供給される、前回の計算部 412 による演算の結果である 5 つの 6 ビットの復号途中結果 D413 ( $u_j$ ) のうちの、前回の計算部 412 による演算の結果である 1 つの復号途中結果

D413 が供給され、その 9 ビットの復号途中結果 D411 (v) と 6 ビットの復号途中結果 D413 ( $u_{dv}$ ) が、減算器 431 に供給される。また、計算器 412<sub>1</sub> には、制御部 417 から制御信号 D419 が供給され、その制御信号 D419 がセレクタ 435 とセレクタ 442 に供給される。

5 減算器 431 は、9 ビットの復号途中結果 D411 (v) から 6 ビットの復号途中結果 D413 ( $u_j$ ) を減算し、その 6 ビットの減算値 D431 を出力する。即ち、減算器 431 は、式 (8) にしたがって演算を行い、その演算の結果である減算値 D431 ( $v_i$ ) を出力する。

減算器 431 により出力された 6 ビットの減算値 D431 のうち、最上位ビット 10 の正負を示す符号ビット D432 (sign ( $v_i$ )) が EXOR 回路 440 に供給され、下位 5 ビットの絶対値 D433 ( $|v_i|$ ) が LUT 432 に供給される。

LUT 432 は、絶対値 D433 ( $|v_i|$ ) に対して、式 (7) における  $\phi(|v_i|)$  の演算を行った 5 ビットの演算結果 D434 ( $\phi(|v_i|)$ ) を読み出し、加算器 433 と FIFO メモリ 438 に供給する。

15 加算器 433 は、演算結果 D434 ( $\phi(|v_i|)$ ) とレジスタ 434 に格納されている 9 ビットの値 D435 とを加算することにより、演算結果 D434 を積算し、その結果得られる 9 ビットの積算値をレジスタ 434 に再格納する。なお、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D411 から求められた絶対値 D433 ( $|v_i|$ ) に対する演算結果が積算された場合、レジスタ 434 はリセットさ 20 れる。

検査行列の 1 行に亘る復号途中結果 D411 が 1 つずつ読み込まれ、レジスタ 434 に 1 行分の演算結果 D434 が積算された積算値が格納された場合、制御部 417 から供給される制御信号 D419 は、0 から 1 に変化する。例えば、行の重み (row weight) が「9」である場合、制御信号 D419 は、1 から 8 クロック目までは、「0」となり、9 クロック目では「1」となる。

25 制御信号 D419 が「1」の場合、セレクタ 435 は、レジスタ 434 に格納されている値、即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果

D411（復号途中結果 v）から求められた  $\phi(|v_i|)$  が積算された 9 ビットの値

D435（ $i = 1$  から  $i = d$ 。までの  $\sum \phi(|v_i|)$ ）を選択し、値 D436 として、レジ  
5 スタ 4 3 6 に出力して格納させる。レジスタ 4 3 6 は、格納している値 D436 を、  
9 ビットの値 D437 として、セレクタ 4 3 5 と加算器 4 3 7 に供給する。制御信  
号 D419 が「0」の場合、セレクタ 4 3 5 は、レジスタ 4 3 6 から供給された値  
D437 を選択し、レジスタ 4 3 6 に出力して再格納させる。即ち、検査行列の 1  
行に亘る全ての 1 に対応する復号途中結果 D411（復号途中結果 v）から求めら  
れた  $\phi(|v_i|)$  が積算されるまで、レジスタ 4 3 6 は、前回積算された  $\phi(|v_i|)$   
を、セレクタ 4 3 5 と加算器 4 3 7 に供給する。

10 一方、FIFO メモリ 4 3 8 は、レジスタ 4 3 6 から新たな値 D437（ $i = 1$  から  
 $i = d$ 。までの  $\sum \phi(|v_i|)$ ）が出力されるまでの間、LUT 4 3 2 が出力した演算  
結果 D434（ $\phi(|v_i|)$ ）を遅延し、5 ビットの値 D438 として減算器 4 3 7 に供給  
する。減算器 4 3 7 は、レジスタ 4 3 6 から供給された値 D437 から、FIFO メモ  
リ 4 3 8 から供給された値 D438 を減算し、その減算結果を、5 ビットの減算値  
15 D439 として LUT 4 3 9 に供給する。即ち、減算器 4 3 7 は、検査行列の 1 行に  
亘る全ての 1 に対応する復号途中結果 D411（復号途中結果 v）から求められた  
 $\phi(|v_i|)$  の積算値から、求めたい枝に対応する復号途中結果、即ち、検査行列の  
所定の 1 に対応する復号途中結果 D411（復号途中結果 v）から求められた  
20  $\phi(|v_i|)$  を減算して、その減算値（ $i = 1$  から  $i = d - 1$  までの  $\sum \phi(|v_i|)$ ）  
を減算値 D439 として LUT 4 3 9 に供給する。

LUT 4 3 9 は、減算値 D439（ $i = 1$  から  $i = d - 1$  までの  $\sum \phi(|v_i|)$ ）に対  
して、式（7）における  $\phi^{-1}(\sum \phi(|v_i|))$  の演算を行った 5 ビットの演算結果  
D440（ $\phi^{-1}(\sum \phi(|v_i|))$ ）を出力する。

以上の処理と並行して、EXOR 回路 4 4 0 は、レジスタ 4 4 1 に格納されてい  
25 る 1 ビットの値 D442 と符号ビット D432 との排他的論理和を演算することによ  
り、符号ビットどうしの乗算を行い、1 ビットの乗算結果 D441 をレジスタ 4 4  
1 に再格納する。なお、検査行列の 1 行に亘る全ての 1 に対応する復号途中結

果 D411 から求められた符号ビット D432 が乗算された場合、レジスタ 4 4 1 はリセットされる。

検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D411 から求められた符号ビット D432 が乗算された乗算結果 D441 ( $i = 1$  から  $d_c$  までの  $\prod \text{sign}(v_i)$ ) がレジスタ 4 4 1 に格納された場合、制御部 4 1 7 から供給される制御信号 D419 は、「0」から「1」に変化する。

制御信号 D419 が「1」の場合、セレクタ 4 4 2 は、レジスタ 4 4 1 に格納されている値、即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D411 から求められた符号ビット D432 が乗算された値 D442 ( $i = 1$  から  $i = d_c$  までの  $\prod \text{sign}(v_i)$ ) を選択し、1 ビットの値 D443 としてレジスタ 4 4 3 に出力して格納させる。レジスタ 4 4 3 は、格納している値 D443 を、1 ビットの値 D444 としてセレクタ 4 4 2 と EXOR 回路 4 4 5 に供給する。制御信号 D419 が「0」の場合、セレクタ 4 4 2 は、レジスタ 4 4 3 から供給された値 D444 を選択し、レジスタ 4 4 3 に出力して再格納させる。即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D411 (復号途中結果 v) から求められた符号ビット D432 が乗算されるまで、レジスタ 4 4 3 は、前回格納した値を、セレクタ 4 4 2 と EXOR 回路 4 4 5 に供給する。

一方、FIFO メモリ 4 4 4 は、レジスタ 4 4 3 から新たな値 D444 ( $i = 1$  から  $i = d_c$  までの  $\prod \text{sign}(v_i)$ ) が EXOR 回路 4 4 5 に供給されるまでの間、符号ビット D432 を遅延し、1 ビットの値 D445 として EXOR 回路 4 4 5 に供給する。EXOR 回路 4 4 5 は、レジスタ 4 4 3 から供給された値 D444 と、FIFO メモリ 4 4 4 から供給された値 D445 との排他的論理和を演算することにより、値 D444 を、値 D445 で除算し、1 ビットの除算結果を除算値 D446 として出力する。即ち、EXOR 回路 4 4 5 は、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D411 から求められた符号ビット D432 ( $\text{sign}(v_i)$ ) の乗算値を、検査行列の所定の 1 に対応する復号途中結果 D411 から求められた符号ビット D432 ( $\text{sign}(v_i)$ ) で除算して、その除算値 ( $i = 1$  から  $i = d_c - 1$  までの

$\prod \text{sign}(v_i)$ ) を除算値 D446 として出力する。

計算器 4 1 2<sub>1</sub> では、LUT 4 3 9 から出力された 5 ビットの演算結果 D440 を下位 5 ビットとするとともに、EXOR 回路 4 4 5 から出力された 1 ビットの除算値 D446 を最上位ビットとする合計 6 ビットが復号途中結果 D412 (復号途中結果 5  $u_j$ ) として出力される。

以上のように、計算器 4 1 2<sub>1</sub> では、式 (7) と式 (8) の演算が行われ、復号途中結果  $u_j$  が求められる。

なお、図 1 5 の検査行列の行の重みの最大は 9 であるため、即ち、計算器 4 1 2<sub>1</sub> に供給される復号途中結果 D411 ( $v$ ) と復号途中結果 D413 ( $u_{dv}$ ) の最大数は 10 9 であるため、計算器 4 1 2<sub>1</sub> は、9 個の復号途中結果 D411 から求められる 9 個の演算結果 D434 ( $\phi(|v_i|)$ ) を遅延させる FIFO メモリ 4 3 8 と、9 個の符号ビット D432 を遅延させる FIFO メモリ 4 4 4 を有している。行の重みが 9 未満の行のメッセージを計算するときには、FIFO メモリ 4 3 8 と FIFO メモリ 4 4 4 における遅延量が、その行の重みの値に減らされる。

15 図 2 2 は、図 1 8 の計算部 4 1 5 の計算器 4 1 5<sub>1</sub> の構成例を示すブロック図である。

なお、図 2 2 では、計算器 4 1 5<sub>1</sub> について説明するが、計算器 4 1 5<sub>2</sub> 乃至計算器 4 1 5<sub>5</sub> も同様に構成される。

また、図 2 2 では、計算器 4 1 2 による第 1 の演算の結果得られる各復号途中結果 ( $u_j$ ) が符号ビットを合わせて合計 6 ビットに量子化されているものとして、計算器 4 1 5<sub>1</sub> を表している。さらに、図 2 2 の計算器 4 1 5<sub>1</sub> には、クロック c<sub>k</sub> が供給され、このクロック c<sub>k</sub> は、必要なブロックに供給されるようになって 20 いる。そして、各ブロックは、クロック c<sub>k</sub> に同期して処理を行う。

25 図 2 2 の計算器 4 1 5<sub>1</sub> は、制御部 4 1 7 から供給される制御信号 D422 に基づいて、受信用メモリ 4 1 6 から 1 つずつ読み込まれる受信データ D417 (受信値  $u_{0i}$ ) と、サイクリックシフト回路 4 1 4 から 1 つずつ読み込まれる復号途中結果 D414 ( $u_j$ ) とを用いて、式 (5) にしたがう第 2 の演算を行う。

即ち、計算器 415<sub>1</sub>では、サイクリックシフト回路 414 から、検査行列の各行の 1 に対応する 6 ビットの復号途中結果 D414（復号途中結果  $u_j$ ）が 1 つずつ読み込まれ、その復号途中結果 D414 が、加算器 471 に供給される。また、計算器 415<sub>1</sub>では、受信用メモリ 416 から 6 ビットの受信データ D417 が 1 つずつ読み込まれ、加算器 475 に供給される。さらに、計算器 415<sub>1</sub>には、制御部 417 から制御信号 D422 が供給され、その制御信号 D422 は、セレクタ 473 に供給される。

加算器 471 は、復号途中結果 D414（復号途中結果  $u_j$ ）とレジスタ 472 に格納されている 9 ビットの値 D471 とを加算することにより、復号途中結果 D414 を積算し、その結果得られる 9 ビットの積算値を、レジスタ 472 に再格納する。なお、検査行列の 1 列に亘る全ての 1 に対応する復号途中結果 D414 が積算された場合、レジスタ 472 はリセットされる。

検査行列の 1 列に亘る復号途中結果 D414 が 1 つずつ読み込まれ、レジスタ 472 に 1 列分の復号途中結果 D414 が積算された値が格納された場合、制御部 417 から供給される制御信号 D422 は、「0」から「1」に変化する。例えば、列の重みが「5」である場合、制御信号 D422 は、1 から 4 クロック目までは「0」となり、5 クロック目では「1」となる。

制御信号 D422 が「1」の場合、セレクタ 473 は、レジスタ 472 に格納されている値、即ち、検査行列の 1 列に亘る全ての枝からの復号途中結果 D414（復号途中結果  $u_j$ ）が積算された 9 ビットの値 D471（ $j = 1$  から  $d_v$  までの  $\sum u_j$ ）を選択し、レジスタ 474 に出力して格納させる。レジスタ 474 は、格納している値 D471 を、9 ビットの値 D472 として、セレクタ 471 と加算器 475 に供給する。制御信号 D422 が「0」の場合、セレクタ 473 は、レジスタ 474 から供給された値 D472 を選択し、レジスタ 474 に出力し再格納させる。即ち、検査行列の 1 列に亘る全ての枝からの復号途中結果 D414（復号途中結果  $u_j$ ）が積算されるまで、レジスタ 474 は、前回積算された値を、セレクタ 473 と加算器 475 に供給する。

加算器 475 は、9 ビットの値 D472 と、受信用メモリ 416 から供給された 6 ビットの受信データ D417 とを加算して、その結果得られる 6 ビットの値を復号途中結果 D415（復号途中結果 v）として出力する。

以上のように、計算器 415<sub>1</sub> では、式（5）の演算が行われ、復号途中結果 v が求められる。

なお、図 8 の検査行列の列の重みの最大は 5 であるため、即ち、計算器 415<sub>1</sub> に供給される復号途中結果  $u_j$  の最大数は 5 であるため、計算器 415<sub>1</sub> は、6 ビットの復号途中結果  $u_j$  を最大 5 個加算する。従って、計算器 415<sub>1</sub> の出力は、9 ビットの値となっている。

図 23 は、図 18 の復号途中結果格納用メモリ 413 の構成例を示すプロック図である。

復号途中結果格納用メモリ 413 は、スイッチ 501 と 504、および 2 つのシングルポート RAM である復号途中結果格納用 RAM 502 と 503 から構成される。

この復号途中結果格納用メモリ 413 の各部について詳細に説明する前に、まず、復号途中結果格納用 RAM 502 と 503 へのデータの格納方法について説明する。

復号途中結果格納用 RAM 502 と 503 は、計算部 412 による第 1 の演算の結果得られ、スイッチ 501 を介して供給された復号途中結果 D412 を格納する。

具体的には、復号途中結果格納用 RAM 502 の第 1 アドレスから第 9 アドレスには、図 15 の検査行列 H の第 1 行目から第 5 行目までの 1 に対応する復号途中結果 D412 (D501) が、各行ともに横方向（列方向）に詰めた形に（0 を無視した形で）格納される。

即ち、第 j 行第 i 列を、(j, i) と表すこととすると、復号途中結果格納用 RAM 502 の第 1 アドレスには、図 15 の検査行列の構成行列である (1, 1) から (5, 5) の  $5 \times 5$  の単位行列の 1 に対応するデータが、第 2 アドレスには、図 15 の検査行列の構成行列である (1, 21) から (5, 25) のシフト行列 ( $5 \times 5$  の単位行

列を右方向に3つだけサイクリックシフトしたシフト行列)の1に対応するデータが格納される。第3アドレスから第8アドレスも同様に図15の検査行列の構成行列と対応づけてデータが格納される。そして、第9アドレスには、検査行列の(1, 86)から(5, 90)のシフト行列(5×5の単位行列のうちの1行目の1を0に置き換えて1つだけ左にサイクリックシフトしたシフト行列)の1に対応するデータが格納される。ここで、図15の検査行列の(1, 86)から(5, 90)のシフト行列においては、1行目に1がないため、第9アドレスにはデータが格納されない。

復号途中格納用RAM502の第10アドレスから第18アドレスには、図15の検査行列の第11行目から第15行目までの1に対応するデータが格納される。即ち、第10アドレスには、検査行列の(11, 6)から(15, 10)の5×5の単位行列を右に3つだけサイクリックシフトした行列の1に対応するデータが格納され、第11アドレスには、検査行列の(11, 11)から(15, 15)の和行列(5×5の単位行列と、5×5の単位行列を右に3つだけサイクリックシフトしたシフト行列との和である和行列)を構成するシフト行列の1に対応するデータが格納される。また、第12アドレスには、検査行列の(11, 6)から(15, 10)の和行列を構成する単位行列の1に対応するデータが格納される。以下、第13アドレスから第18アドレスについても、検査行列に対応づけてデータが格納される。

即ち、重みが2以上の構成行列については、その構成行列を、重みが1であるP×Pの単位行列、そのコンポーネントである1のうち1個以上が0になった準単位行列、または単位行列もしくは準単位行列をサイクリックシフトしたシフト行列のうちの複数の和の形で表現したときの、その重みが1の単位行列、準単位行列、またはシフト行列の1の位置に対応するデータ(単位行列、準単位行列、またはシフト行列に属する枝に対応するメッセージの復号途中結果)は、同一アドレスに格納される。

同様に、復号途中格納用RAM502の第19アドレスから第27アドレスには、図15の検査行列に対応づけて、第21行目から第25行目までの1に対応する

データが格納される。即ち、復号途中結果格納用 RAM 502 のワード数は、27である。

復号途中結果格納用 RAM 503 の第1アドレスから第9アドレスには、図15の検査行列 H の第6行目から第10行目までの 1 に対応する復号途中結果  
5 D412(D502) が、各行ともに横方向（列方向）に詰めた形に（0を無視した形で）格納される。

即ち、復号途中結果格納用 RAM 503 の第1アドレスには、検査行列の構成行列である(6, 1)から(10, 5)の和行列（ $5 \times 5$  の単位行列を右に1つだけサイクリックシフトした第1のシフト行列と、右に2つだけサイクリックシフトした第2のシフト行列の和である和行列）を構成する第1のシフト行列の 1 に対応するデータが、第2アドレスには、検査行列の構成行列である(6, 1)から(10, 5)の和行列を構成する第2のシフト行列の 1 に対応するデータが格納される。以下、第3アドレスから第9アドレスも同様に検査行列の構成行列と対応づけてデータが格納される。

15 同様に、復号途中格納用 RAM 503 の第10アドレスから第18アドレスには、図15の検査行列の第16行目から第20行目までの 1 に対応するデータが、第19アドレスから第27アドレスには、検査行列の第26行目から第30行目までの 1 に対応するデータが、図15の検査行列に対応づけて格納される。即ち、復号途中結果格納用 RAM 503 のワード数は、27である。

20 上述したように、復号途中結果格納用 RAM 502 と 503 のワード(word)数は、27である。即ち、ワード数は、検査行列の行の重み(row weight)の 9 と行数の 30 を乗算し、その乗算結果(検査行列の 1 の数)を、同時に読み出す復号途中結果 D501 の数の 5 で除算し、さらに、復号途中結果格納用メモリ 413 が有する復号途中結果格納用 RAM の個数の 2 で除算した値となる。

25 以下、図23の復号途中結果格納用メモリ 413 の各部の動作について詳細に説明する。

復号途中結果格納用メモリ 413 には、計算部 412 により第1の演算が行わ

- れる場合、計算部 412 から第 1 の演算の結果得られる復号途中結果 D412 ( $u_j$ ) が供給され、その復号途中結果 D412 が復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 のうちの一方の所定のアドレスに書き込まれると同時に、他方から、前回の計算部 412 による第 1 の演算の結果得られた復号途中結果 D412 ( $u_j$ ) が読み出され、計算部 412 に出力される。一方、計算部 415 により第 2 の演算が行われる場合、復号途中結果格納用メモリ 413 は、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 に書き込みを行わず、どちらか一方の RAM の所定のアドレスから復号途中結果を読み出して、サイクリックシフト回路 414 に供給する。
- スイッチ 501 には、計算部 412 から 5 つの復号途中結果 D412 が供給されるとともに、その復号途中結果 D412 を書き込むメモリとして、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 の一方の選択を表す制御信号 D420<sub>1</sub> が制御部 417 から供給される。スイッチ 501 は、制御信号 D420<sub>1</sub> に基づいて、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 の一方を選択し、その選択した一方に、5 つの復号途中結果 D412 を供給する。
- 復号途中結果格納用 RAM 502 には、スイッチ 501 から 5 つの復号途中結果 D412 が、復号途中結果 D501 として供給されるとともに、制御部 417 からアドレスを表す制御信号 D420<sub>2</sub> が供給される。復号途中結果格納用 RAM 502 は、制御信号 D402<sub>2</sub> が表すアドレスに既に格納されている前回の計算部 412 による第 1 の演算の結果得られた 5 つの復号途中結果 D501 を読み出し、復号途中結果 D503 としてスイッチ 504 に供給する。また、復号途中結果格納用 RAM 502 は、制御信号 D402<sub>2</sub> が表すアドレスに、スイッチ 501 から供給された 5 つの復号途中結果 D501 を格納する(書き込む)。
- 復号途中結果格納用 RAM 503 には、スイッチ 501 から 5 つの復号途中結果 D412 が、復号途中結果 D502 として供給されるとともに、制御部 417 からアドレスを表す制御信号 D420<sub>3</sub> が供給される。復号途中結果格納用 RAM 503 は、制御信号 D402<sub>3</sub> が表すアドレスに既に格納されている前回の計算部 412 による第

1 の演算の結果得られた 5 つの復号途中結果 D502 を読み出し、復号途中結果 D504 としてスイッチ 504 に供給する。また、復号途中結果格納用 RAM 502 は、制御信号 D420<sub>3</sub> が表すアドレスに、スイッチ 501 から供給された 5 つの復号途中結果 D502 を格納する(書き込む)。

- 5     スイッチ 504 には、復号途中結果格納用 RAM 502 から復号途中結果 D503 が供給されるか、あるいは復号途中結果格納用 RAM 503 から復号途中結果 D504 が供給される。また、制御部 417 から、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 の一方の選択を表す制御信号 D420<sub>4</sub> が供給される。  
10    スイッチ 504 は、制御信号 D420<sub>1</sub> に基づいて、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 の一方を選択し、その選択した一方から供給された 5 つの復号途中結果を、5 つの復号途中結果 D413 として計算部 412 とサイクリックシフト回路 414 に供給する。

15    図 24 は、復号途中結果格納用メモリ 413 の復号途中結果格納用 RAM 502 と復号途中結果格納用 RAM 503 の読み出しと書き込みの動作を説明するタイミングチャートである。

なお、図 24において、横軸は、時間 (t) を表している。

復号途中結果格納用メモリ 413 では、計算部 412 により第 1 の演算が行われる場合、復号途中結果格納用 RAM 502 が、制御信号 D420<sub>2</sub> に基づいて、既に格納している、前回の計算部 412 の第 1 の演算の結果得られた復号途中結果 D501 のうち、同一アドレスに格納している検査行列の第 1 行目から第 5 行目までの 1 に対応する復号途中結果 D501 を、5 つ単位で 9 回読み出し、スイッチ 504 を介して、計算部 412 に供給する。即ち、図 15 の検査行列 H の行重みは、9 であるため、検査行列 H の各行の 1 に対応する復号途中結果は 9 つあり、復号途中結果格納用 RAM 502 は、第 1 行目から第 5 行目までの 1 に対応する 5 つの復号途中結果 D501 を、5 つ単位で 9 回読み出す。

次に、復号途中結果格納用 RAM 503 は、制御信号 D420<sub>3</sub> に基づいて、既に格納している、前回の計算部 412 による第 1 の演算の結果得られた復号途中結果

D502 のうち、同一アドレスに格納している検査行列の第 6 行目から第 10 行目までの 1 に対応する復号途中結果 D502 を、5 つ単位で 9 回続けて読み出し、スイッチ 504 を介して、計算部 412 に供給する。それと同時に、復号途中結果格納用 RAM 502 には、計算部 412 により、いま行われている第 1 の演算の結果得られる検査行列の第 1 行目から第 5 行目までの 1 に対応する 5 つの復号途中結果 D412 がスイッチ 501 を介して、復号途中結果 D501 として供給され、復号途中結果格納用 RAM 502 は、その復号途中結果 D501 を、制御信号 D420<sub>2</sub>に基づいて、既に読み出された復号途中結果 D503 が格納されていたアドレスに 9 回続けて格納する。

その後、復号途中結果格納用 RAM 502 は、制御信号 D420<sub>2</sub>に基づいて、既に格納している、前回の計算部 412 による第 1 の演算の結果得られた復号途中結果 D501 のうち、同一アドレスに格納している検査行列の第 11 行目から第 15 行目までの 1 に対応する復号途中結果 D501 を、5 つ単位で 9 回続けて読み出し、スイッチ 504 を介して、計算部 412 に供給する。それと同時に、復号途中結果格納用 RAM 503 には、計算部 412 により、いま行われている第 1 の演算の結果得られる検査行列の第 6 行目から第 10 行目までの 1 に対応する 5 つの復号途中結果 D412 がスイッチ 501 を介して、復号途中結果 D502 として供給され、復号途中結果格納用 RAM 503 は、その復号途中結果 D502 を、制御信号 D420<sub>3</sub>に基づいて、既に読み出された復号途中結果 D504 が格納されていたアドレスに 9 回続けて格納する。

以後、同様に、計算部 412 による第 1 の演算の結果得られる検査行列の全ての 1 に対応する復号途中結果が、復号途中結果格納用 RAM 502 または復号途中結果格納用 RAM 503 に格納されるまで、復号途中結果格納用 RAM 502 と復号途中結果格納用 RAM 503 は、9 回ずつの読み出しあり書き込みを交互に行う。

復号途中結果格納用メモリ 413 では、計算部 415 による第 2 の演算が行われる場合、制御信号 D420<sub>2</sub>に基づいて、復号途中結果格納用 RAM 502 から既に格納されている第 1 の演算の結果得られる復号途中結果 D503 を読み出すか、あ

るいは制御信号 D420<sub>3</sub>に基づいて、復号途中結果格納用 RAM 503 から、既に格納されている第 1 の演算の結果得られる復号途中結果 D504 を読み出し、その読み出した復号途中結果をスイッチ 504 を介して、サイクリックシフト回路 414 に供給する。

5 図 25 は、図 18 の復号装置 400 の復号処理を説明するフローチャートである。この処理は、例えば、受信用メモリ 416 に復号すべき受信データが格納されたとき、開始される。

ステップ S50において、サイクリックシフト回路 414 は、復号途中結果格納用メモリ 413 から供給された後述するステップ S56 で格納される 5 つの復号途中結果 D413 を、サイクリックシフトし、計算部 415 に供給する。

具体的には、サイクリックシフト回路 414 には、復号途中結果格納用メモリ 413 から 5 つの復号途中結果 D413 が供給されるとともに、制御部 417 から、その復号途中結果 D413 に対応する検査行列の 1 が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D421 が供給される。サイクリックシフト回路 414 は、制御信号 D421 を元に、5 つの復号途中結果 D413 をサイクリックシフトし (並べ替え) 、その結果を復号途中結果 D414 として、計算部 415 に供給する。

なお、受信用メモリ 416 から供給された受信データ D417 に対して、まだ第 1 の演算が行われておらず、復号途中結果格納用メモリ 413 に復号途中結果 D413 が格納されていない場合、計算部 415 は、復号途中結果  $u_i$  を初期値に設定する。

ステップ S51において、計算部 415 は、第 2 の演算を行い、その演算の結果である復号途中結果 D415 を復号途中結果格納用メモリ 410 に供給する。

具体的には、計算部 415 には、ステップ S50 でサイクリックシフト回路 414 から 5 つの復号途中結果 D414 が供給されるとともに、受信データ用メモリ 416 から 5 つの受信データ D417 が供給され、復号途中結果 D415 と受信データ D417 が、計算部 415 の計算器 415<sub>1</sub> 乃至 415<sub>5</sub> それぞれに 1 つずつ供給

される。さらに、計算部 415 には、制御部 417 から制御信号 D422 が供給され、その制御信号 D422 が計算器 415<sub>1</sub> 乃至 415<sub>5</sub> に供給される。

計算器 415<sub>1</sub> 乃至 415<sub>5</sub> は、復号途中結果 D414 と受信データ D417 を用いて、制御信号 D422 に基づいて、式 (5) にしたがって、それぞれ演算を行い、  
5 その演算の結果得られる検査行列の列に対応する復号途中結果 D415(v) を復号途中結果格納用メモリ 410 に供給する。

ステップ S51 の処理後は、ステップ S52 に進み、復号途中結果格納用メモリ 410 は、ステップ S51 で計算部 415 から供給された復号途中結果 D415 を、同一アドレスに格納し、ステップ S53 に進む。

10 ステップ S53において、制御部 417 は、計算部 415 により、検査行列の列に対応する全ての復号途中結果 D415 が演算されたかどうかを判定し、全ての復号途中結果 D415 が演算されていないと判定した場合、ステップ S50 に戻り、上述した処理を繰り返す。

一方、ステップ S53において、制御部 417 は、計算部 415 により、検査行列の列に対応する全ての復号途中結果 D415 が演算されたと判定した場合、ステップ S54 に進み、サイクリックシフト回路 411 は、復号途中結果格納用メモリ 410 から供給される復号途中結果 D410(v) をサイクリックシフトする。

具体的には、サイクリックシフト回路 411 には、復号途中結果格納用メモリ 410 から 5 つの復号途中結果 D410 が供給されるとともに、制御部 417 から、  
20 その復号途中結果 D410 に対応する検査行列の 1 が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D418 が供給される。サイクリックシフト回路 411 は、制御信号 D418 を元に、5 つの復号途中結果 D410 をサイクリックシフトし (並べ替え) 、その結果を復号途中結果 D411 として、計算部 412 に供給する。

25 ステップ S54 の処理後は、ステップ S55 に進み、計算部 412 は、第 1 の演算を行い、その演算結果である復号途中結果 D412 をサイクリックシフト回路 414 に供給する。

具体的には、計算部 4 1 2 には、ステップ S 5 4 でサイクリックシフト回路 4 1 1 から 5 つの復号途中結果 D411(v) が供給されるとともに、後述するステップ S 5 6 で既に格納された前回の計算部 4 1 2 による第 1 の演算の結果得られた 5 つの復号途中結果 D412 (D413) (u<sub>j</sub>) が供給され、その復号途中結果 D411 と復号 5 途中結果 D413 が、計算部 4 1 2 の計算器 4 1 2<sub>1</sub> 乃至 4 1 2<sub>5</sub> のそれぞれに 1 つずつ供給される。さらに、計算部 4 1 2 には、制御部 4 1 7 から制御信号 D419 が供給され、その制御信号 D419 が計算器 4 1 2<sub>1</sub> 乃至 4 1 2<sub>5</sub> に供給される。

計算器 4 1 2<sub>1</sub> 乃至 4 1 2<sub>5</sub> は、それぞれ復号途中結果 D411 と復号途中結果 D413 とを用いて、制御信号 D419 に基づいて、式 (7) と式 (8) にしたがって、 10 それぞれ演算を行い、その演算の結果得られる復号途中結果 D412 (u<sub>j</sub>) を復号 途中結果格納用メモリ 4 1 3 に供給する。

ステップ S 5 5 の処理後は、ステップ S 5 6 に進み、復号途中結果格納用メモリ 4 1 3 は、ステップ S 5 5 で計算部 4 1 2 から供給された 5 つの復号途中結果 D412 を、同一のアドレスに格納し、ステップ S 5 7 に進む。

15 ステップ S 5 7において、制御部 4 1 7 は、計算部 4 1 2 により、検査行列の全ての 1 に対応する復号途中結果 D412 が演算されたかどうかを判定し、全ての復号途中結果が演算されていないと判定した場合、ステップ S 5 4 に戻り、上述 20 した処理を繰り返す。

一方、ステップ S 5 7において、制御部 4 1 7 は、計算部 4 1 2 により、全ての 1 に対応する復号途中結果 D412 が演算されたと判定した場合、処理を終了する。

なお、復号装置 4 0 0 は、復号回数だけ図 2 5 の復号処理を繰り返し行ない、最後の第 2 の演算の結果得られるメッセージ D415 が、最終的な復号結果として出力される。

25 上述した説明では、復号途中結果格納用メモリ 4 1 3 は、2 つのシングルポート RAM から構成したが、1 つの RAM に対して読み出しと書き込みが同時に起 こらないようにすれば、3 つ以上の RAM から構成してもよい。例えば、RAM の物

理的なビットが足りない場合には、複数の RAM を用いて同じ制御信号を与えることで、論理的に 1 つの RAM とみなすことができる。

また、枝データ（枝に対応するメッセージ）が欠けている箇所に関しては、メモリ格納時（復号途中結果格納用メモリ 410 と 413 へのデータ格納時）には、  
5 何のメッセージも格納せず、また、演算時（計算部 412 での第 1 の演算時と計算部 415 での第 2 の演算時）にも何の演算も行わない。

図 26 は、本発明を適用した図 15 の検査行列で表現される LDPC 符号を復号する復号装置の他の一実施の形態の構成例を示すブロック図である。

図 26 の復号装置 600 では、図 16 A と C の枝データ格納メモリ 316 が、  
10 枝データ格納メモリ 316 に比べて容量の小さい復号途中結果格納用メモリ 613 になっている。

復号装置 600 は、復号途中結果格納用メモリ 610、サイクリックシフト回路 611、5 つの計算器 612<sub>1</sub> 乃至計算器 612<sub>5</sub> からなる計算部 612、復号途中結果格納用メモリ 613、サイクリックシフト回路 614、5 つの計算器 615<sub>1</sub> 乃至計算器 615<sub>5</sub> からなる計算部 615、受信用メモリ 616、および制御部 617 から構成される。  
15

ここで、図 27 乃至図 30 を用いて、図 26 の計算部 612 の計算器 612<sub>1</sub> 乃至計算器 612<sub>5</sub>、および図 30 の計算部 615 の計算器 615<sub>1</sub> 乃至計算器 615<sub>5</sub> と、図 10 のチェックノード計算器 101 および図 11 のバリアブルノード計算器 103 との関係について説明する。  
20

図 27 と図 28 は、前述の図 10 のチェックノード計算器 101 と図 11 のバリアブルノード計算器 103 とそれぞれ同一の図である。また、図 29 は、計算器 612<sub>k</sub> ( $k=1, 2, \dots, 5$ ) の構成例を示しており、図 30 は、計算器 615<sub>k</sub> ( $k=1, 2, \dots, 5$ ) の構成例を示している。

図 26 の復号装置 600 では、計算器 612<sub>k</sub> がチェックノード演算を行い、計算部 615<sub>k</sub> が、バリアブルノード演算をおこなうのではなく、計算器 612<sub>k</sub> がチェックノード演算の一部を、計算器 615<sub>k</sub> がチェックノード演算の他の一  
25

部とバリアブルノード演算を行う。

即ち、図29の計算器 $612_k$ は、ブロックD' とE' から構成される。ブロックD' は、図27のチェックノード計算器101の一部である、検査行列の各列の全ての枝に対応するメッセージ $v_i$  の絶対値に対して  $\phi$  の演算を行った値を積算するブロックDと同様に構成されている。また、ブロックE' は、検査行列の各列の全ての枝に対応するメッセージ $v_i$  の符号ビットを乗算するブロックEと同様に構成されている。

一方、図30の計算器 $615_k$ は、ブロックF'、G'、H' とから構成される。ブロックF' は、図19のチェックノード計算器101の他の一部である、検査行列の各列の全ての枝に対応するメッセージ $v_i$  の符号ビットの乗算値から、求めたい枝に対応するメッセージ $v_i$  の符号ビットを除算するとともに、検査行列の各列の全ての枝に対応するメッセージ $v_i$  の絶対値に対して  $\phi$  の演算を行った値の積算値から、求めたい枝に対応するメッセージ $v_i$  の絶対値に対して  $\phi$  の演算を行った値を減算した値に対して、 $\phi^{-1}$  の演算を行うブロックFと同様に構成されている。また、ブロックG' は、メッセージ $v_i$  の絶対値に対して  $\phi$  の演算を行うブロックGと同様に構成され、ブロックH' は、図20のバリアブルノード計算器103のバリアブルノード演算を行うブロックHと同様に構成されている。

そして、図29の計算器 $612_k$ は、ブロックAとブロックBによる演算の結果、即ち、チェックノード演算の一部を行った復号途中結果 $w$ を復号途中結果格納用メモリ613に供給し、図30の計算器 $615_k$ は、チェックノード演算の他の一部とバリアブルノード演算を行った復号途中結果 $v_i'$ を復号途中結果格納用メモリ610に供給する。

従って、図26の復号装置600は、計算器 $612_k$ の演算と計算器 $615_k$ の演算とを交互に行うことにより、チェックノード演算とバリアブルノード演算を行い、復号を行うことができる。

なお、図30の計算器 $615_k$ では、復号途中結果格納用メモリ610に格納

されている求めたい枝に対応する復号途中結果  $v_i'$  を用いて、ブロック C で、計算器 6 1 2<sub>k</sub> の演算の結果得られる復号途中結果  $w$  の絶対値から、求めたい枝に対応する復号途中結果  $v_i'$  を減算するとともに、復号途中結果  $w$  の符号ビットと、求めたい枝に対応する復号途中結果  $v_i'$  の符号ビットを乗算するので、図 27 の 5 FIFO メモリ 127 と FIFO メモリ 133 が必要ない。

次に、計算部 6 1 2 の計算器 6 1 2<sub>1</sub> 乃至計算器 6 1 2<sub>5</sub> で行われる演算と、計算部 6 1 5 の計算器 6 1 5<sub>1</sub> 乃至計算器 6 1 5<sub>5</sub> で行われる演算について、式を用いて説明する。

計算部 6 1 2 は、以下の式 (9) にしたがう第 1 の演算を行い、その第 1 の演算の結果である復号途中結果  $w$  を復号途中結果格納用メモリ 6 1 3 に供給して格納させる。計算部 6 1 5 は、上述した式 (1) と、以下の式 (10) と (11) にしたがう第 2 の演算を行い、その第 2 の演算の結果である復号途中結果  $v_i'$  を復号途中結果格納用メモリ 6 1 0 に供給して格納させる。

$$w = \sum_{i=1}^{d_c} |v_i'| \times \prod_{i=1}^{d_c} \text{sign}(v_i') \quad \dots \quad (9)$$

$$15 \quad u_j = \phi^{-1}(|w| - |v_i'|) \times \text{sign}(v_i') \times \text{sign}(w) \quad \dots \quad (10)$$

$$v_i' = \phi(|v_i'|) \times \text{sign}(v_i) \quad \dots \quad (11)$$

即ち、式 (9) にしたがう第 1 の演算の結果得られる復号途中結果  $w$  は、式 (1)、式 (10)、式 (11) にしたがう第 2 の演算の結果得られる検査行列  $H$  の  $j$  行のすべての 1 に対応するチェックノード演算の復号途中結果  $v_i'$  の絶対値  $|v_i'|$  の総和と符号ビット  $\text{sign}(v_i')$  の乗算値とを乗算したものであるので、上述した式 (7) にしたがうチェックノード演算によって求められる  $u_j$  は、式 (10) に示すように、式 (9) にしたがう第 1 の演算の結果得られる復号途中結果  $w$  の絶対値  $|w|$  から、検査行列  $H$  の  $j$  行の、各列の “1” (枝) に対応する (複数の) 復号途中結果  $v_i'$  のうち、メッセージを求めたい枝に対応する復号途中結果  $v_i'$  の絶対値  $|v_i'|$  を引いた値を用いて表すことができる。

復号装置 600 では、計算部 612 による式(9)にしたがう第1の演算と、計算部 615 による式(1)、式(10)、式(11)にしたがう第2の演算とが交互に行われ、計算部 615 が、最後の第1の演算の結果を用いて、式(5)にしたがう演算を行い、その演算結果を復号結果として出力することにより、

5 LDPC 符号の繰り返し復号を行う。

即ち、復号装置 600 では、計算部 612 が、計算部 615 による第2の演算の結果である検査行列 H の j 行のすべての 1 に対応する復号途中結果  $v_i'$  を用いて、第1の演算を行い、その演算の結果得られる検査行列の各行に対応する復号途中結果 w を復号途中結果格納用メモリ 613 に格納する。従って、復号途中結果格納用メモリ 613 の容量は、検査行列の “1” の数より少ない検査行列の行数と復号途中結果 w の量子化ビット数とを乗算した値となる。なお、計算部 615 は、計算部 612 による第1の演算の結果である検査行列 H の i 列の各行に対応する復号途中結果 w と受信値  $u_{0i}$  を用いて、第2の演算を行い、その演算の結果得られる検査行列の i 列の 1 (枝) に対応するチェックノード演算の復号途中結果  $v_i'$  を復号途中結果格納用メモリ 610 に格納する。従って、復号途中結果格納用メモリ 610 に必要な容量は、バリアブルノード演算の結果を格納する図 16A と B の枝データ格納メモリ 311 と同様に、検査行列の 1 の数と復号途中結果  $v_i'$  の量子化ビット数とを乗算した値となる。

従って、復号装置 600 では、図 16A と B の枝データ格納メモリ 311 に比べて、復号途中結果格納用メモリ 610 のメモリの容量を削減することができ、これにより、復号装置 600 の回路規模を小さくすることができる。

以下、図 26 の復号装置 600 の各部の動作について詳細に説明する。

復号途中結果格納用メモリ 610 は、制御信号 D618 に基づいて、計算部 615 から供給される 5 つの復号途中結果 D615 をまとめて格納すると同時に、既に 25 格納してある 5 つの復号途中結果 D615 を読み出し、復号途中結果 D610 として、サイクリックシフト回路 611 と計算部 615 に供給する。即ち、復号途中結果格納用メモリ 610 は、サイクリックシフト回路 611 に供給する復号途中結果

D610 の読み出しどと、計算部 615 から供給される復号途中結果 D615 の書き込みとを、同時に行う。

なお、復号途中結果格納用メモリ 610 には、計算部 615 の第 2 の演算により演算された検査行列の 1 (枝) に対応する復号途中結果  $v_i'$  (第 2 の復号途中結果) が格納されるので、復号途中結果格納用メモリ 610 に格納されるデータ量、即ち、復号途中結果格納用メモリ 610 に必要とされる記憶容量は、復号途中結果の量子化ビット数と、検査行列の 1 の数 (全枝数) との乗算値となる。

復号途中結果格納用メモリ 610 は、例えば、5 つの復号途中結果を同時に読み書き可能な、2 つのシングルポート RAM から構成される。復号途中結果格納用メモリ 610 には、計算部 615 から 5 つの復号途中結果 D615 が供給されるとともに、制御部 617 から復号途中結果 D615 の読み書きを制御する制御信号 D618 が供給される。

サイクリックシフト回路 611 には、復号途中結果格納用メモリ 610 から 5 つの復号途中結果 D610 が供給されるとともに、制御部 617 から、その復号途中結果 D610 に対応する検査行列の 1 が、検査行列において元となる単位行列などを幾つサイクリックシフトであるかの情報 (Matrix データ) を表す制御信号 D619 が供給される。サイクリックシフト回路 611 は、制御信号 D619 を元に、5 つの復号結果 D610 を並べ替えるサイクリックシフトを行い、その結果を復号途中結果 D611 として、計算部 612 に供給する。

計算部 612 は、5 つの計算器 612<sub>1</sub> 乃至 612<sub>5</sub> からなる。計算部 612 には、サイクリックシフト回路 611 から 5 つの復号途中結果 D611 (第 2 の復号途中結果) ( $v_i'$ ) が供給され、その 5 つの復号途中結果 D611 (第 1 の復号途中結果) ( $w$ ) が、計算器 612<sub>1</sub> 乃至 612<sub>5</sub> のそれぞれに供給される。また、計算部 612 には、制御部 617 から制御信号 D620 が供給され、その制御信号 D620 が、計算器 612<sub>1</sub> 乃至 612<sub>5</sub> に供給される。なお、制御信号 D620 は、5 つの計算器 612<sub>1</sub> 乃至 612<sub>5</sub> に共通の信号である。

計算器 612<sub>1</sub> 乃至 612<sub>5</sub> は、それぞれ復号途中結果 D611 を用いて、式

(9) にしたがって第1の演算を行い、復号途中結果 D612(w)を求める。計算部 612 は、計算器 612<sub>1</sub>乃至 612<sub>5</sub>による演算の結果得られる5つの復号途中結果 D612 を復号途中結果格納用メモリ 613 に供給する。

復号途中結果格納用メモリ 613 には、計算部 612 から、計算部 612 による第1の演算の結果である検査行列の行に対応する5つの復号途中結果 D612 が供給され、復号途中結果格納用メモリ 613 は、計算部 612 から供給された5つの復号途中結果 D612 を、第1アドレスから順に格納（記憶）する。

即ち、復号途中結果格納用メモリ 613 の第1アドレスには、検査行列の行に対応する復号途中結果のうち、第1行目から第5行目の復号途中結果 w が格納される。そして、同様に、第2アドレスには、第6行目から第10行目の復号途中結果 w が格納され、第3アドレスには、第11行目から第15行目の復号途中結果 w が格納される。以後、同様に、第16行目から第30行までの復号途中結果 w が、5個ずつ、第4アドレスから第6アドレスまで格納され、計60個の復号途中結果 w が復号途中結果格納用メモリ 613 に格納される。従つて、復号途中結果格納用メモリ 610 のワード（word）数は、図15の検査行列 H の行数である30を、同時に読み書きする復号途中結果の数である5で割り算した6となる。

また、復号途中結果格納用メモリ 613 は、既に格納してある5つの復号途中結果 D613 から、計算部 615 が求めようとする復号途中結果 v<sub>i'</sub> の対応する検査行列 H の列において“1”になっている復号途中結果 w を5つ同時に読み出し、復号途中結果 D613 として、サイクリックシフト回路 614 に供給する。

なお、復号途中結果格納用メモリ 613 は、例えば、5つの復号途中結果を同時に読み書き可能な、シングルポート RAM で構成される。また、復号途中結果格納用メモリ 613 には、計算部 612 の第1の演算により演算された行に対応する復号途中結果 w が格納されるので、復号途中結果格納用メモリ 613 に格納されるデータ量、即ち、復号途中結果格納用メモリ 613 に必要とされる記憶容量は、復号途中結果の量子化ビット数と、検査行列 H の行数との乗算値であ

る。

サイクリックシフト回路 614 には、復号途中結果格納用メモリ 613 から 5 つの復号途中結果 D613（復号途中結果 w）が供給されるとともに、制御部 617 から、その復号途中結果 D613 に対応する検査行列の 1 が検査行列において元 5 となる単位行列などを幾つサイクリックシフトしたものであるかの情報

（Matrix データ）を表す制御信号 D621 が供給される。サイクリックシフト回路 614 は、制御信号 D621 を元に、5 つの復号途中結果 D613 を並べ替えるサイクリックシフトを行い、その結果を復号途中結果 D614 として、計算部 615 に供給する。

10 計算部 615 は、5 つの計算器 615<sub>1</sub> 乃至 615<sub>5</sub> からなる。バリアブルノード計算部 615 には、サイクリックシフト回路 614 から 5 つの復号途中結果 D614(w) が供給されるとともに、復号途中結果格納用メモリ 610 から 5 つの復号途中結果 D610 (v<sub>i'</sub>) が供給され、その復号途中結果 D614 と復号途中結果 D610 が、計算器 615<sub>1</sub> 乃至 615<sub>5</sub> のそれぞれに供給される。また、計算部 6 15 には、受信用メモリ 617 から 5 つの受信データ D617 が供給され、その受信データ D617 が、計算器 615<sub>1</sub> 乃至 615<sub>5</sub> のそれぞれに供給される。さらに、計算部 617 には、制御部 617 から制御信号 D622 が供給され、その制御信号 D622 が計算器 615<sub>1</sub> 乃至 615<sub>5</sub> に供給される。なお、制御信号 D622 は、5 つの計算器 617<sub>1</sub> 乃至 617<sub>5</sub> に共通の信号である。

20 計算器 615<sub>1</sub> 乃至 615<sub>5</sub> は、それぞれ復号途中結果 D614 と D611、受信データ D617 (LDPC 符号) とを用いて、式 (1)、式 (10)、式 (11) にしたがって、それぞれ第 2 の演算を行い、検査行列の各列の 1 に対応する 5 つの復号途中結果 D615 (v<sub>i'</sub>) を求める。計算部 615 は、計算器 615<sub>1</sub> 乃至 615<sub>5</sub> の第 2 の演算の結果得られる 5 つの復号途中結果 D615 を、復号途中結果格納用メモリ 610 に供給する。

受信用メモリ 616 は、通信路を通して受信した受信値（符号ビット）D616 から計算した符号ビットの 0 らしさの値である受信 LLR（対数尤度比）を、受信

データ D617 として格納する。

即ち、受信用メモリ 616 の第 1 のアドレスには、検査行列の列に対応する受信データ D617 のうち、検査行列の第 1 列目から第 5 列目までに対応する受信データ D617 が格納される。そして、第 2 のアドレスには、検査行列の第 6 列目から第 10 列目までに対応する受信データ D617 が格納され、第 3 アドレスには、検査行列の第 11 列目から第 16 列目までに対応する受信データ D617 が格納される。以後、同様に、第 4 アドレスから第 18 アドレスまでに、検査行列の第 17 列目から第 90 列目までに対応する受信データ D617 が、5 つずつ格納される。

そして、受信用メモリ 616 は、既に格納している受信データ D617 を計算部 615 による第 2 の演算に必要となる順番に 5 つずつ同時に読み出し、計算部 615 に供給する。

なお、受信用メモリ 616 は、例えば、シングルポート RAM から構成される。また、受信用メモリ 616 に格納されるデータ量、即ち、受信用メモリ 616 に必要とされる記憶容量は、LDPC 符号の符号長と、受信データの量子化ビット数との乗算値である。さらに、受信用メモリ 616 のワード (word) 数は、LDPC 符号の符号長、即ち、検査行列の列数である 90 を、同時に読み出す受信データ D617 の数である 5 で割り算した値の 18 である。

制御部 617 は、制御信号 D618 を復号途中結果格納用メモリ 610 に、制御信号 D619 をサイクリックシフト回路 611 に供給することにより、それぞれを制御する。また、制御部 617 は、制御信号 D620 を計算部 612 に、制御信号 D621 をサイクリックシフト回路 614 に、制御信号 D622 を計算部 615 に供給することにより、それぞれを制御する。

復号途中結果格納用メモリ 610、サイクリックシフト回路 611、計算部 612、復号途中結果格納用メモリ 613、サイクリックシフト回路 614、計算部 615 の順で、データが一巡することで、復号装置 600 は、1 回の復号を行うことができる。復号装置 600 では、所定の回数だけ繰り返して復号が行われた後、計算部 615 が、式 (5) にしたがう演算を行い、その演算結果が最終的

な復号結果として出力される。

図29は、図26の計算部612の計算器612<sub>1</sub>の構成例を示すブロック図である。

なお、図29では、計算器612<sub>1</sub>について説明するが、計算器612<sub>2</sub>乃至計算器612<sub>5</sub>も同様に構成される。

また、図29では、計算器615による第2の演算の結果得られる各復号途中結果( $v_i'$ )が6ビットに量子化されているものとして、計算器612<sub>1</sub>を表している。さらに、図29の計算器612<sub>1</sub>には、クロックckが供給され、このクロックckは、必要なブロックに供給されるようになっている。そして、各ブロックは、クロックckに同期して処理を行う。

図29の計算器612<sub>1</sub>は、制御部617から供給される制御信号D620に基づいて、サイクリックシフト回路611から1つずつ読み込まれる復号途中結果D611( $v_i'$ )を用いて、式(9)にしたがう第1の演算を行う。

即ち、計算器612<sub>1</sub>には、サイクリックシフト回路611から供給される5つの6ビットの復号途中結果D611( $v_i'$ )のうちの、1つの復号途中結果D611が供給され、最上位ビットの符号ビットD631がEXOR回路635に供給されるとともに、その6ビットの復号途中結果D611( $v_i'$ )の下位5ビットの絶対値D632(| $v_i'$ |)が、加算器631に供給される。また、計算器612<sub>1</sub>には、制御部617から制御信号D620が供給され、その制御信号D620がセレクタ633とセレクタ637に供給される。

加算器631は、絶対値D632(| $v_i'$ |)とレジスタ632に格納されている9ビットの値D633とを加算することにより、絶対値D632(| $v_i'$ |)を積算し、その結果得られる9ビットの積算値をレジスタ632に再格納する。なお、検査行列の1行に亘る全ての1に対応する復号途中結果D611から求められた絶対値D632(| $v_i'$ |)が積算された場合、レジスタ632はリセットされる。

検査行列の1行に亘る復号途中結果D611が1つずつ読み込まれ、レジスタ632に1行分の絶対値D632が積算された積算値が格納された場合、制御部61

7 から供給される制御信号 D620 は、0 から 1 に変化する。例えば、行の重み (row weight) が「9」である場合、制御信号 D620 は、1 から 8 クロック目までは、「0」となり、9 クロック目では「1」となる。

制御信号 D620 が「1」の場合、セレクタ 633 は、レジスタ 632 に格納されている値、即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 (復号途中結果  $v_i'$ ) の絶対値 D632 ( $|v_i'|$ ) が積算された 9 ビットの値 D633 ( $i = 1$  から  $i = d$  までの  $\sum |v_i'|$ ) を選択し、値 D634 として、レジスタ 634 に出力して格納させる。レジスタ 634 は、格納している値 D634 を、9 ビットの値 D635 として、セレクタ 633 に供給するとともに、出力する。制御信号 D620 が「0」の場合、セレクタ 633 は、レジスタ 634 から供給された値 D635 を選択し、レジスタ 634 に出力して再格納させる。即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 (復号途中結果  $v_i'$ ) の絶対値 D632 ( $|v_i'|$ ) が積算されるまで、レジスタ 634 は、前回積算された  $|v_i'|$  を、セレクタ 633 に供給するとともに、出力する。

以上の処理と並行して、EXOR 回路 635 は、レジスタ 636 に格納されている 1 ビットの値 D637 と符号ビット D631 との排他的論理和を演算することにより、符号ビットどうしの乗算を行い、1 ビットの乗算結果 D636 をレジスタ 636 に再格納する。なお、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 の符号ビット D631 が乗算された場合、レジスタ 636 はリセットされる。

検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 から求められた符号ビット D631 が乗算された乗算結果 D636 ( $i = 1$  から  $d$  までの  $\prod \text{sign}(v_i')$ ) がレジスタ 636 に格納された場合、制御部 617 から供給される制御信号 D620 は、「0」から「1」に変化する。

制御信号 D620 が「1」の場合、セレクタ 637 は、レジスタ 636 に格納されている値、即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 の符号ビット D631 が乗算された値 D637 ( $i = 1$  から  $i = d$  までの

11 sign( $v_i'$ )) を選択し、1ビットの値 D638 としてレジスタ 638 に出力して格納させる。レジスタ 638 は、格納している値 D638 を、1ビットの値 D639 としてセレクタ 637 に供給するとともに、出力する。制御信号 D620 が「0」の場合、セレクタ 637 は、レジスタ 638 から供給された値 D639 を選択し、  
5 レジスタ 638 に出力して再格納させる。即ち、検査行列の 1 行に亘る全ての 1 に対応する復号途中結果 D611 (復号途中結果  $v_i'$ ) の符号ビット D631 が乗算されるまで、レジスタ 638 は、前回格納した値を、セレクタ 637 に供給するとともに、出力する。

計算器 612<sub>1</sub> では、レジスタ 634 から出力された 9 ビットの値 D635 ( $i = 1$  から  $i = d_0$  までの  $\sum |v_i'|$ ) を下位 9 ビットとするとともに、レジスタ 638 から出力された 1 ビットの値 D639 (sign( $v_i'$ )) を最上位ビットとする合計 10 ビットが復号途中結果 D612 (復号途中結果 w) として出力される。

以上のように、計算器 612<sub>1</sub> では、式 (9) の演算が行われ、復号途中結果 w が求められる。

15 図 30 は、図 26 の計算部 615 の計算器 615<sub>1</sub> の構成例を示すブロック図である。

なお、図 30 では、計算器 615<sub>1</sub> について説明するが、計算器 615<sub>2</sub> 乃至計算器 615<sub>5</sub> も同様に構成される。

また、図 30 では、計算器 612 による第 1 の演算の結果得られる各復号途中結果 (w) が符号ビットを合わせて合計 10 ビットに量子化され、復号途中結果格納用メモリ 610 から供給される、前回の第 2 の演算の結果得られた各復号途中結果 ( $u_j$ ) が符号ビットを合わせて 6 ビットに量子化されているものとして、計算器 615<sub>1</sub> を表している。さらに、図 30 の計算器 615<sub>1</sub> には、クロック c\_k が供給され、このクロック c\_k は、必要なブロックに供給されるようになってい  
20 る。そして、各ブロックは、クロック c\_k に同期して処理を行う。  
25

図 30 の計算器 615<sub>1</sub> は、制御部 617 から供給される制御信号 D622 に基づいて、受信用メモリ 616 から 1 つずつ読み込まれる受信データ D617 (受信

値  $u_{0i}$  ) 、サイクリックシフト回路 614 から 1 つずつ読み込まれる復号途中結果 D614 (w) 、および復号途中結果格納用メモリ 610 から 1 つずつ読み込まれる前回の計算部 615 による第 2 の演算の結果得られた復号途中結果 D610 ( $v_i'$ ) とを用いて、式 (1) 、式 (10) 、式 (11) にしたがう第 2 の演算 5 を行う。

即ち、計算器 615<sub>1</sub> では、サイクリックシフト回路 614 から、検査行列の行に対応する 10 ビットの復号途中結果 D614 (復号途中結果 w) が 1 つずつ読み込まれとともに、復号途中結果格納用メモリ 610 から、前回の計算部 615 による第 2 の演算の結果得られた 6 ビットの復号途中結果 D610 (復号途中結果 10  $v_i'$ ) が 1 つずつ読み込まれ、その復号途中結果 D614 の最上位ビットの符号ビット D651 (sign(w)) と復号途中結果 D610 の最上位ビットの符号ビット D653 (sign ( $u_j$ )) が、EXOR 回路 653 に供給されるとともに、その復号途中結果 D614 の下位 9 ビットの絶対値 D652 (|w|) と復号途中結果 D610 の下位 9 ビットの符号ビット D653 (| $v_i'$ |) が、減算器 651 に供給される。また、計算器 6 15<sub>1</sub> では、受信用メモリ 616 から 6 ビットの受信データ D617 が 1 つずつ読み込まれ、加算器 658 に供給される。さらに、計算器 615<sub>1</sub> には、制御部 6 17 から制御信号 D622 が供給され、その制御信号 D622 は、セレクタ 656 に供給される。

減算器 651 は、絶対値 D652 から絶対値 D654 を減算し、その 5 ビットの減算値 D655 を LUT 652 に供給する。LUT 652 は、その減算値 D655 に対して、 $\phi^{-1}$  の演算を行った 5 ビットの演算結果 D656 ( $\phi^{-1} (|w| - |v_i'|)$ ) を出力する。

一方、EXOR 回路 653 は、符号ビット D651 (sign (w)) と符号ビット D653 (sign ( $v_i'$ )) との排他的論理和を演算することにより、符号ビット D651 と符号ビット D653 を乗算し、1 ビットの乗結果を乗算値 D657 として出力する。そして、LUT 652 から供給される 5 ビットの演算結果 D656 を下位 5 ビット ( $\phi^{-1} (|w| - |v_i'|)$ ) とするとともに、EXOR 回路 653 から供給される 1 ビ

ットの値 D657 ( $\text{sign}(w) \times \text{sign}(v_i')$ ) を最上位ビットとした 6 ビットの値 D658 が、加算器 654 に供給されるとともに、FIFO メモリ 659 に供給される。

以上のように、式 (10) にしたがう演算が行われ、その演算の結果である 6 ビットの値 D658 ( $u_j$ ) が、加算器 654 に供給されるとともに、FIFO メモリ 6

5 59 に供給される。

加算器 654 は、6 ビットの値 D658 ( $u_j$ ) とレジスタ 655 に格納されている 9 ビットの値 D659 とを加算することにより、値 D658 を積算し、その結果得られる 9 ビットの積算値を、レジスタ 655 に再格納する。なお、検査行列の 1 列に亘る全ての 1 に対応する値 D658 が積算された場合、レジスタ 655 はリセ

10 ットされる。

検査行列の 1 列に亘る値 D658 が 1 つずつ読み込まれ、レジスタ 655 に 1 列分の値 D658 が積算された値が格納された場合、制御部 617 から供給される制御信号 D622 は、「0」から「1」に変化する。例えば、列の重みが「5」である場合、制御信号 D622 は、1 から 4 クロック目までは「0」となり、5 クロック目では「1」となる。

制御信号 D622 が「1」の場合、セレクタ 656 は、レジスタ 655 に格納されている値、即ち、検査行列の 1 列に亘る 1 に対応する値 D658 ( $u_j$ ) が積算された 9 ビットの値 D659 ( $j = 1$  から  $d_v$  までの  $\sum u_j$ ) を選択し、レジスタ 657 に出力して格納させる。レジスタ 657 は、格納している値 D659 を、9 ビットの値 D660 として、セレクタ 471 と加算器 658 に供給する。制御信号 D622 が「0」の場合、セレクタ 656 は、レジスタ 657 から供給された値 D660 を選択し、レジスタ 657 に出力し再格納させる。即ち、検査行列の 1 列に亘る 1 に対応する値 D658 ( $u_j$ ) が積算されるまで、レジスタ 657 は、前回積算された値を、セレクタ 656 と加算器 658 に供給する。

25 加算器 658 は、9 ビットの値 D660 と、受信用メモリ 616 から供給された 6 ビットの受信データ D617 とを加算して、その結果得られる 9 ビットの値 D661 を供給する。

計算器 615 では、最後の演算を行う場合、加算器 658 が、9 ビットの値 D661 を最終的な復号結果として出力する。即ち、計算部 615 は、式 (5) にしたがって演算を行う。

一方、FIFO メモリ 659 は、レジスタ 665 から新たな値 D660 ( $j = 1$  から  $j = d_v$  までの  $\sum u_j$ ) が出力されるまでの間、6 ビットの値 D658 ( $u_j$ ) を遅延し、6 ビットの値 D662 として減算器 660 に供給する。減算器 660 は、9 ビットの値 D660 から 6 ビットの値 D662 を減算し、その減算値 D663 を出力する。即ち、減算器 660 は、検査行列の 1 列に亘る 1 に対応する値 D658 の積算値から、求めたい枝に対応する値、即ち検査行列の所定の 1 に対応する値 D658 ( $u_j$ ) を減算して、その減算値 ( $i = 1$  から  $i = d_v - 1$  までの  $\sum u_j$ ) を 6 ビットの減算値 D663 として出力する。

以上のように、式 (1) にしたがう演算が行われ、その演算の結果である 6 ビットの減算値 D663 ( $v_i$ ) が出力される。そして、減算器 660 から出力された 6 ビットの減算値 D663 の下位 5 ビットの絶対値 ( $|v_i|$ ) が、LUT 661 に供給されるとともに、最上位ビットの符号ビット (sign ( $v_i$ )) が値 D665 として出力される。

LUT 661 は、絶対値 ( $|v_i|$ ) に対して、 $\phi$  の演算を行った 5 ビットの演算結果 D666 ( $\phi (|v_i|)$ ) を出力する。そして、LUT 661 から出力された 5 ビットの演算結果 D666 ( $\phi (|v_i|)$ ) を下位 5 ビットとともに、値 D665 (sign ( $v_i$ )) を最上位ビットとした合計 6 ビットを、復号途中結果 ( $v_i'$ ) として復号途中結果格納用メモリ 610 に供給する。

以上のように、計算器 615<sub>1</sub> では、式 (1)、式 (10)、式 (11) の演算が行われ、復号途中結果  $v_i'$  が求められる。

なお、図 15 の検査行列の列の重みの最大は 5 であるため、即ち、計算器 615<sub>1</sub> に供給される復号途中結果 D614 (w) と復号途中結果 D610 ( $v_i'$ ) の最大数は 5 であるため、計算器 615<sub>1</sub> は、5 個の復号途中結果 D614 と復号途中結果 D610 から求められる 5 個の演算結果 D658 ( $u_j$ ) を遅延させる FIFO メモリ 65

9を有している。列の重みが5未満の行のメッセージを計算するときには、FIFOメモリ659における遅延量が、その列の重みの値に減らされる。

図31は、図26の復号途中結果格納用メモリ610の構成例を示すブロック図である。

5 復号途中結果格納用メモリ610は、スイッチ701と704、および2つのシングルポートRAMである復号途中結果格納用RAM702と703から構成される。

この復号途中結果格納用メモリ610の各部について詳細に説明する前に、まず、復号途中結果格納用RAM702と703へのデータの格納方法について説明  
10 する。

復号途中結果格納用RAM702と703は、計算部612による第1の演算の結果得られ、スイッチ701を介して供給された復号途中結果D615を格納する。

具体的には、復号途中結果格納用RAM702の第1アドレスから第5アドレスには、図15の検査行列Hの第1列目から第5列目までの1に対応する復号途中結果D615(D701)が、各行ともに横方向(列方向)に詰めた形に(0を無視した形で)格納される。

即ち、第j行第i列を、(j, i)と表すこととすると、復号途中結果格納用RAM702の第1アドレスには、図15の検査行列の(1, 1)から(5, 5)の $5 \times 5$ の単位行列の1に対応するデータが、第2アドレスには、図15の検査行列の(6, 1)から(10, 5)の和行列( $5 \times 5$ の単位行列を右に1つだけサイクリックシフトした第1のシフト行列と、右に2つだけサイクリックシフトした第2のシフト行列との和である和行列)を構成する第1のシフト行列の1の位置に対応するデータが格納される。また、第3アドレスには、検査行列の(6, 1)から(10, 5)の和行列を構成する第2のシフト行列の1の位置に対応するデータが格納される。以下、第4アドレスおよび第5アドレスについても、図15の検査行列に対応づけて、データが格納される。

復号途中格納用RAM702の第6アドレスから第10アドレスには、図15の

検査行列の第 11 列目から第 15 列目までの 1 に対応するデータが格納される。即ち、第 6 アドレスには、検査行列の(11, 11)から(15, 15)の和行列（ $5 \times 5$  の単位行列と、 $5 \times 5$  の単位行列を右に 3 つだけサイクリックシフトした第 1 のシフト行列との和である和行列）を構成する第 1 のシフト行列の 1 の位置に対応するデータが格納され、第 7 アドレスには、検査行列の(11, 11)から(15, 15)の和行列を構成する単位行列の 1 に対応するデータが格納される。以下、第 8 アドレスから第 10 アドレスについても、検査行列に対応づけてデータが格納される。

同様に、復号途中格納用 RAM 702 の第 10 アドレスから第 28 アドレスには、図 15 の検査行列に対応づけて、第 21 列目から第 25 列目まで、第 31 列目から第 35 列目まで、第 41 列目から第 45 列目まで、第 51 列目から第 55 列目まで、第 61 列目から第 65 列目まで、第 71 列目から第 75 列目まで、第 81 列目から第 85 列目までの 1 に対応するデータが格納される。即ち、復号途中結果格納用 RAM 702 のワード数は、28 である。

復号途中結果格納用 RAM 703 の第 1 アドレスから第 5 アドレスには、図 15 の検査行列 H の第 6 列目から第 10 列目までの 1 に対応する復号途中結果 D615(D702) が、各行ともに横方向（列方向）に詰めた形に（0 を無視した形で）格納される。

即ち、復号途中結果格納用 RAM 703 の第 1 アドレスには、検査行列の構成行列である(6, 1)から(10, 5)の和行列（ $5 \times 5$  の単位行列を右に 1 つだけサイクリックシフトした第 1 のシフト行列と、右に 2 つだけサイクリックシフトした第 2 のシフト行列の和である和行列）を構成する第 1 のシフト行列の 1 に対応するデータが、第 2 アドレスには、検査行列の構成行列である(6, 1)から(10, 5)の和行列を構成する第 2 のシフト行列の 1 に対応するデータが格納される。以下、第 3 アドレスから第 5 アドレスも同様に検査行列の構成行列と対応づけてデータが格納される。

同様に、復号途中格納用 RAM 703 の第 6 アドレスから第 26 アドレスには、図 15 の検査行列の第 16 列目から第 20 列目まで、第 26 列目から第 30 列目

まで、第36列目から第40列目まで、第46列目から第50列目まで、第56列目から第60列目まで、第66列目から第70列目まで、第76列目から第80列目まで、第86列目から第90列目までの1に対応するデータが、図15の検査行列に対応づけて格納される。即ち、復号途中結果格納用RAM703のワード数は、26である。

上述したように、復号途中結果格納用RAM702のワード(word)数は、28であり、復号途中結果格納用RAM703のワード数は、26である。

図32は、復号途中結果格納用メモリ610の復号途中結果格納用RAM702と復号途中結果格納用RAM703の読み出しと書き込みの動作を説明するタイミングチャートである。

なお、図32において、横軸は、時間(t)を表している。

復号途中結果格納用メモリ610では、計算部612による第1の演算が行われる場合、制御部617から供給される制御信号D720<sub>2</sub>に基づいて、復号途中結果格納用RAM702から既に格納されている第2の演算の結果得られる復号途中結果D703を読み出すか、あるいは制御部617から供給される制御信号D720<sub>3</sub>に基づいて、復号途中結果格納用RAM703から、既に格納されている第2の演算の結果得られる復号途中結果D704を読み出し、その読み出した復号途中結果をスイッチ704を介して、サイクリックシフト回路614に供給する。

復号途中結果格納用メモリ610には、計算部615により第2の演算が行われる場合、計算部615から第2の演算の結果得られる復号途中結果D615'が供給され、その復号途中結果D615が復号途中結果格納用RAM702または復号途中結果格納用RAM703のうちの一方の所定のアドレスに書き込まれると同時に、他方から、前回の計算部615による第2の演算の結果得られた復号途中結果D610'が読み出され、サイクリックシフト回路614を介して、計算部615に出力される。

スイッチ701には、計算部615から5つの復号途中結果D615が供給されるとともに、その復号途中結果D615を書き込むメモリとして、復号途中結果格

納用 RAM 702 または復号途中結果格納用 RAM 703 の一方の選択を表す制御信号 D720<sub>1</sub> が供給される。スイッチ 701 は、制御信号 D720<sub>1</sub>に基づいて、復号途中結果格納用 RAM 702 または復号途中結果格納用 RAM 703 の一方を選択し、その選択した一方に、5つの復号途中結果 D612 を供給する。

- 5 復号途中結果格納用 RAM 702 には、スイッチ 701 から5つの復号途中結果 D612 が、復号途中結果 D701 として供給されるとともに、制御部 617 からアドレスを表す制御信号 D702<sub>2</sub> が供給される。復号途中結果格納用 RAM 702 は、制御信号 D720<sub>2</sub> が表すアドレスに既に格納されている前回の計算部 615 による第 2 の演算の結果得られた5つの復号途中結果 D701 を読み出し、復号途中結果 10 D703 としてスイッチ 704 に供給する。また、復号途中結果格納用 RAM 702 は、制御信号 D720<sub>2</sub> が表すアドレスに、スイッチ 701 から供給された5つの復号途中結果 D702 を格納する(書き込む)。

- 復号途中結果格納用 RAM 703 には、スイッチ 701 から5つの復号途中結果 D615 が、復号途中結果 D702 として供給されるとともに、制御部 617 からアドレスを表す制御信号 D720<sub>3</sub> が供給される。復号途中結果格納用 RAM 703 は、制御信号 D720<sub>3</sub> が表すアドレスに既に格納されている前回の計算部 615 による第 15 第2の演算の結果得られた5つの復号途中結果 D702 を読み出し、復号途中結果 D704 としてスイッチ 704 に供給する。また、復号途中結果格納用 RAM 702 は、制御信号 D720<sub>3</sub> が表すアドレスに、スイッチ 701 から供給された5つの復号途中結果 D702 を格納する(書き込む)。

- 20 スイッチ 704 には、復号途中結果格納用 RAM 702 から復号途中結果 D703 が供給されるか、あるいは復号途中結果格納用 RAM 703 から復号途中結果 D704 が供給される。また、制御部 617 から、復号途中結果格納用 RAM 702 または復号途中結果格納用 RAM 703 の一方の選択を表す制御信号 D720<sub>4</sub> が供給 25 される。スイッチ 704 は、制御信号 D720<sub>4</sub>に基づいて、復号途中結果格納用 RAM 702 または復号途中結果格納用 RAM 703 の一方を選択し、その選択した一方から供給された5つの復号途中結果を、5つの復号途中結果 D610 として計

算部 615 に供給する。

復号途中結果格納用メモリ 610 では、計算部 615 により第 2 の演算が行われる場合、復号途中結果格納用 RAM 702 が、制御信号 D720<sub>2</sub>に基づいて、既に格納している、前回の計算部 615 の第 2 の演算の結果得られた復号途中結果 5 D701 のうち、同一アドレスに格納している検査行列の第 1 列目から第 5 列目までの 1 に対応する復号途中結果 D701 を、5 つ単位で、5 回読み出し、スイッチ 704 を介して、計算部 615 に供給する。即ち、図 15 の検査行列 H の列重みは、5 であるため、検査行列 H の各列の 1 に対応する復号途中結果は 5 つあり、復号途中結果格納用 RAM 702 は、第 1 行列目から第 5 列目までの 1 に対応 10 する復号途中結果 D701 を、5 つ単位で 5 回読み出す。

次に、復号途中結果格納用 RAM 703 は、制御信号 D720<sub>3</sub>に基づいて、既に格納している、前回の計算部 615 による第 2 の演算の結果得られた復号途中結果 D702 のうち、同一アドレスに格納している検査行列の第 6 列目から第 10 列目までの 1 に対応する 5 つの復号途中結果 D702 を、5 回続けて読み出し、スイッチ 704 とサイクリックシフト回路 614 を介して、計算部 615 に供給する。それと同時に、復号途中結果格納用 RAM 702 には、計算部 615 により、いま行かれている第 2 の演算の結果得られる検査行列の第 1 列目から第 5 列目までの 1 に対応する 5 つの復号途中結果 D615 がスイッチ 701 を介して、復号途中結果 D701 として供給され、復号途中結果格納用 RAM 702 は、その復号途中結果 20 D701 を、制御信号 D720<sub>2</sub>に基づいて、既に読み出された復号途中結果 D703 が格納されていたアドレスに 5 回続けて格納する。

その後、復号途中結果格納用 RAM 702 は、制御信号 D720<sub>2</sub>に基づいて、既に格納している、前回の計算部 615 による第 2 の演算の結果得られた復号途中結果 D701 のうち、同一アドレスに格納している検査行列の第 11 列目から第 15 列目までの 1 に対応する復号途中結果 D701 を、5 つ単位で 5 回続けて読み出し、スイッチ 704 を介して、計算部 615 に供給する。それと同時に、復号途中結果格納用 RAM 703 には、計算部 615 により、いま行かれている第 2 の演算の

結果得られる検査行列の第 6 列目から第 10 列目までの 1 に対応する 5 つの復号途中結果 D612 がスイッチ 701 を介して、復号途中結果 D702 として供給され、復号途中結果格納用 RAM 703 は、その復号途中結果 D702 を、制御信号 D720<sub>3</sub> に基づいて、既に読み出された復号途中結果 D704 が格納されていたアドレスに 5 回続けて格納する。

以後、同様に、計算部 615 による第 2 の演算の結果得られる検査行列の全ての 1 に対応する復号途中結果が、復号途中結果格納用 RAM 702 または復号途中結果格納用 RAM 703 に格納されるまで、復号途中結果格納用 RAM 702 と復号途中結果格納用 RAM 703 は、5 回ずつの読み出しありは書き込みを交互に行う。

図 33 は、図 26 の復号装置 600 の復号処理を説明するフローチャートである。この処理は、例えば、受信用メモリ 616 に復号すべき受信データが格納されたとき、開始される。

ステップ S70において、サイクリックシフト回路 614 は、復号途中結果格納用メモリ 613 から供給された後述するステップ S76 で格納された 5 つの復号途中結果 D613 を、並べ替えてサイクリックシフトを行い、計算部 615 に供給する。

具体的には、サイクリックシフト回路 614 には、復号途中結果格納用メモリ 613 から 5 つの復号途中結果 D613 が供給されるとともに、制御部 617 から、その復号途中結果 D613 に対応する検査行列の 1 が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報（Matrix データ）を表す制御信号 D621 が供給される。サイクリックシフト回路 614 は、制御信号 D621 を元に、5 つの復号途中結果 D613 をサイクリックシフトし（並べ替え）、その結果を復号途中結果 D614 として、計算部 615 に供給する。

なお、受信用メモリ 616 から供給された受信データ D617 に対して、まだ第 1 の演算が行われておらず、復号途中結果格納用メモリ 613 に復号途中結果 D612 が格納されていない場合、計算部 615 は、初期値に設定する。

ステップ S71において、計算部 615 は、第 2 の演算を行い、その演算の結

果である復号途中結果 D615 を復号途中結果格納用メモリ 610 に供給する。

具体的には、計算部 615 には、ステップ S70 でサイクリックシフト回路 614 から 5 つの復号途中結果 D614 が供給されるとともに、直前の後述するステップ S72 で復号途中結果格納用メモリ 610 から復号途中結果 D610 が供給される。また、受信データ用メモリ 616 から 5 つの受信データ D617 が供給され、5 つの復号途中結果 D615 と D610、受信データ D617 が、計算部 615 の計算器 615<sub>1</sub> 乃至 615<sub>5</sub> のそれぞれに 1 つずつ供給される。さらに、計算部 615 には、制御部 617 から制御信号 D622 が供給され、その制御信号 D622 が計算器 615<sub>1</sub> 乃至 615<sub>5</sub> に供給される。

計算器 615<sub>1</sub> 乃至 615<sub>5</sub> は、復号途中結果 D614 と D610 と、受信データ D617 とを用いて、制御信号 D622 に基づいて、式 (1)、式 (10)、式 (11) にしたがって、それぞれ演算を行い、その演算の結果得られる検査行列の各列の 1 に対応する復号途中結果 D615(v<sub>i'</sub>) を復号途中結果格納用メモリ 610 に供給する。

ステップ S71 の処理後は、ステップ S72 に進み、復号途中結果格納用メモリ 610 は、ステップ S71 で計算部 615 から供給された復号途中結果 D615 を、同一アドレスに格納するとともに、既に格納している復号途中結果 D615 (D610) を読み出して、サイクリックシフト回路 611 と計算部 615 に供給する。

ステップ S72 の処理後は、ステップ S73 に進み、制御部 617 は、計算部 615 により、検査行列の各列の 1 に対応する全ての復号途中結果 D615 が演算されたかどうかを判定し、全ての復号途中結果 D615 が演算されていないと判定した場合、ステップ S70 に戻り、上述した処理を繰り返す。

一方、ステップ S73において、制御部 617 は、計算部 615 により、全ての復号途中結果 D615 が演算されたと判定した場合、ステップ S74 に進み、サイクリックシフト回路 611 は、復号途中結果格納用メモリ 610 から供給される復号途中結果 D610(v<sub>i'</sub>) をサイクリックシフトする。

具体的には、サイクリックシフト回路 611 には、復号途中結果格納用メモリ 610 から 5 つの復号途中結果 D610 が供給されるとともに、制御部 617 から、その復号途中結果 D610 に対応する検査行列の 1 が検査行列において元となる単位行列などを幾つサイクリックシフトしたものであるかの情報 (Matrix データ) を表す制御信号 D619 が供給される。サイクリックシフト回路 611 は、制御信号 D619 を元に、5 つの復号途中結果 D610 をサイクリックシフトし (並べ替え) 、その結果を復号途中結果 D611 として、計算部 612 に供給する。

5 ステップ S74 の処理後は、ステップ S75 に進み、計算部 612 は、第 1 の演算を行い、その演算結果である復号途中結果 D612 をサイクリックシフト回路 10 614 に供給する。

具体的には、計算部 612 には、ステップ S74 でサイクリックシフト回路 611 から 5 つの復号途中結果 D611( $v_i'$ ) が供給され、その復号途中結果 D611 が、計算部 612 の計算器 612<sub>1</sub> 乃至 612<sub>5</sub> のそれぞれに 1 つずつ供給される。さらに、計算部 612 には、制御部 617 から制御信号 D621 が供給され、その制御信号 D621 が計算器 612<sub>1</sub> 乃至 612<sub>5</sub> に供給される。

15 計算器 612<sub>1</sub> 乃至 612<sub>5</sub> は、それぞれ復号途中結果 D611 を用いて、制御信号 D619 に基づいて、式 (9) にしたがって、それぞれ演算を行い、その演算の結果得られる検査行列の行に対応する復号途中結果 D612 (w) を復号途中結果格納用メモリ 613 に供給する。

20 ステップ S75 の処理後は、ステップ S76 に進み、復号途中結果格納用メモリ 613 は、ステップ S75 で計算部 612 から供給された復号途中結果 D612 を、同一アドレスに格納し、ステップ S77 に進む。

25 ステップ S77において、制御部 617 は、計算部 612 により、検査行列の全ての行に対応する復号途中結果 D612 が演算されたかどうかを判定し、全ての復号途中結果が演算されていないと判定した場合、ステップ S74 に戻り、上述した処理を繰り返す。

一方、ステップ S77において、制御部 617 は、計算部 612 により、全て

の行に対応する復号途中結果 D612 が演算されたと判定した場合、処理を終了する。

なお、復号装置 600 は、復号回数だけ図 33 の復号処理を繰り返し行ない、計算部 621 により上述した式（5）にしたが演算の結果得られる値 D661 が、  
5 最終的な復号結果として出力される。

上述した説明では、復号途中結果格納用メモリ 610 は、2つのシングルポート RAM から構成したが、1つの RAM に対して読み出しと書き込みが同時に起こらないようすれば、3つ以上の RAM から構成してもよい。例えば、RAM の物理的なビットが足りない場合には、複数の RAM を用いて同じ制御信号を与える  
10 ことで、論理的に1つの RAM とみなすことができる。

また、枝データ（枝に対応するメッセージ）が欠けている箇所に関しては、メモリ格納時（復号途中結果格納用メモリ 610 と 613 へのデータ格納時）には、何のメッセージも格納せず、また、演算時（計算部 612 での第1の演算時と計算部 615 での第2の演算時）にも何の演算も行わない。

15 また、図 16A と図 16B のサイクリックシフト回路 314 および 320、図 18 のサイクリックシフト回路 411 および 414、図 26 のサイクリックシフト回路 611 および 614 には、バレルシフタを用いると回路規模を小さくしながら所望の操作を実現できる。

上述の場合には、説明を簡単にするために、P が 5 の場合、即ち、検査行列を構成する構成行列の行数および列数が 5 の場合を例に挙げたが、構成行列の行数および列数 P は必ずしも 5 である必要はなく、検査行列によって異なる値を取ることもあり得る。例えば、P は 360 や 392 であってもよい。

また、本実施の形態では、符号長 90、符号化率 2/3 の LDPC 符号を用いたが、LDPC 符号の符号長や符号化率は、幾つであっても構わない。例えば、構成行列の行数および列数 P が 5 の場合、枝総数が 5 以下であれば、どんな符号長、符号化率の LDPC 符号でも、制御信号を代えるだけで、図 16A 乃至図 16C の復号装置 300、図 18 の復号装置 400、図 26 の復号装置 600 を用いて復号

可能である。

さらに、構成行列の行数および列数 P が所定の値で、枝の総数がある値以下、という条件を満たすある LDPC 符号の復号装置は、その条件を満たす、任意の符号長で、任意の符号化率の LDPC 符号を復号することができる。

5 検査行列が、構成行列の行数および列数 P の倍数でない場合は、検査行列の端数の外側にすべて 0 (all 0) の成分を付けて P の倍数とみなして適用できることがある。

次に、上述した一連の処理は、ハードウェアにより行うこともできるし、ソフトウェアにより行うこともできる。一連の処理をソフトウェアによって行う場合  
10 には、そのソフトウェアを構成するプログラムが、汎用のコンピュータ等にインストールされる。

そこで、図 3 4 は、上述した一連の処理を実行するプログラムがインストールされるコンピュータの一実施の形態の構成例を示している。

15 プログラムは、コンピュータに内蔵されている記録媒体としてのハードディスク 905 や ROM 903 に予め記録しておくことができる。

あるいはまた、プログラムは、フレキシブルディスク、CD-ROM (Compact Disc Read Only Memory), MO (Magneto Optical) ディスク、DVD (Digital Versatile Disc)、磁気ディスク、半導体メモリなどのリムーバブル記録媒体 911 に、一時的あるいは永続的に格納 (記録) しておくことができる。このよう 20 なリムーバブル記録媒体 911 は、いわゆるパッケージソフトウェアとして提供することができる。

なお、プログラムは、上述したようなリムーバブル記録媒体 911 からコンピュータにインストールする他、ダウンロードサイトから、デジタル衛星放送用の人工衛星を介して、コンピュータに無線で転送したり、LAN (Local Area Network)、インターネットといったネットワークを介して、コンピュータに有線で転送し、コンピュータでは、そのようにして転送されてくるプログラムを、通信部 908 で受信し、内蔵するハードディスク 905 にインストールすること

ができる。

コンピュータは、CPU(Central Processing Unit)902を内蔵している。CPU902には、バス901を介して、入出力インターフェース910が接続されおり、CPU902は、入出力インターフェース910を介して、ユーザによって、  
5 キーボードや、マウス、マイク等で構成される入力部907が操作等されることにより指令が入力されると、それにしたがって、ROM(Read Only Memory)903に格納されているプログラムを実行する。あるいは、また、CPU902は、ハードディスク905に格納されているプログラム、衛星若しくはネットワークから転送され、通信部908で受信されてハードディスク905にインストールされたプログラム、またはドライブ909に装着されたリムーバブル記録媒体911  
10 から読み出されてハードディスク905にインストールされたプログラムを、RAM(Random Access Memory)904にロードして実行する。これにより、CPU902は、上述したフローチャートにしたがった処理、あるいは上述したプロック図の構成により行われる処理を行う。そして、CPU902は、その処理結果を、  
15 必要に応じて、例えば、入出力インターフェース910を介して、LCD(Liquid Crystal Display)やスピーカ等で構成される出力部906から出力、あるいは、通信部908から送信、さらには、ハードディスク905に記録等させる。

ここで、本明細書において、コンピュータに各種の処理を行わせるためのプログラムを記述する処理ステップは、必ずしもフローチャートとして記載された順序に沿って時系列に処理する必要はなく、並列的あるいは個別に実行される処理(例えば、並列処理あるいはオブジェクトによる処理)も含むものである。  
20

また、プログラムは、1のコンピュータにより処理されるものであっても良いし、複数のコンピュータによって分散処理されるものであっても良い。さらに、プログラムは、遠方のコンピュータに転送されて実行されるものであっても良い。  
25 以上のように、 $P \times P$  の単位行列、そのコンポーネントの1のうち1個以上が0になった準単位行列、単位行列もしくは準単位行列をサイクリックシフトしたシフト行列、単位行列、準単位行列、もしくはシフト行列の複数の和である和行

列、 $P \times P$  の 0 行列の組合せで表わすことができる検査行列を持つ LDPC 符号の復号を、チェックノードとバリアブルノードの演算を  $P$  個同時に使うアーキテクチャ(architecture)を採用することにより、ノード演算を、 $P$  個同時に使うことで動作周波数を実現可能な範囲に抑えることができ、多数の繰り返し復号を行うことを可能にしつつ、メモリ (FIFO や RAM) への書き込みと読み出し時に、異なるアドレスへの同時アクセスが起きることを防止することができる。

さらに、図 16 A 乃至図 16 C の復号装置 300 を繰り返し用いて、図 15 の検査行列で表わされる LDPC 符号を復号する場合には、269 個の枝をチェックノード、バリアブルノード毎に 5 個ずつ演算することが可能であることから、1 回の復号に、 $269/5 \times 2 = 108$  クロック動作すればよいことになる。50 回の復号には、90 個の符号情報を受信する間に、 $108 \times 50 = 5400$  クロック動作すればよいことになり、受信周波数の約 60 倍の動作周波数でよいことになる。従って、図 16 A 乃至図 16 C の復号装置 300 によれば、各ノード演算を一つずつ行う図 9 の復号装置に比べて、1/5 の動作周波数で済むことになる。また、回路規模の面から見ても、メモリの大きさは同じであるため、論理回路が多少大きくなっても全体への影響は小さいと言える。

さらに、図 18 の復号装置 400 と図 26 の復号装置 600 は、図 16 A 乃至図 16 C の復号装置 300 に比べて、メモリの容量が小さくなっている。

例えば、LDPC 符号の検査行列が図 15 の検査行列であり、LDPC 符号の量子化ビット数が 6 ビットである場合、図 16 A 乃至図 16 C の復号装置 300 では、枝データ格納メモリに、全枝数の  $269 \times 6 = 1614$  ビットの容量を有する RAM 2 つ、即ち、2 つの RAM で  $1614 \times 2 = 3228$  ビットの容量が必要であった。これに対して、例えば、復号途中結果  $v$  の量子化ビット数が 9 ビットである場合、図 18 の復号装置 400 では、復号途中結果格納用メモリ 413 に、全枝数の 1614 ビットの容量を有する RAM と、復号途中結果格納用メモリ 410 に、LDPC 符号の符号長 (検査行列の列数) と復号途中結果  $v$  の量子化ビット数との乗算値、即ち  $90 \times 9 = 810$  ビットの容量を有する RAM を備えれば

よく、復号装置の回路規模を小さくすることができる。さらに、図18の復号装置400では、第2の演算を行う計算部415において、FIFOメモリを有する必要がないので、ロジックの回路規模を小さくすることができる。

また、例えば、LDPC符号の検査行列が図15の検査行列で、復号途中結果vの量子化ビット数が10ビットである場合、図26の復号装置600では、復号途中結果格納用メモリ610に、全枝数の1614ビットの容量を有するRAMと、復号途中結果格納用メモリ613に、検査行列の行数と復号途中結果vとの乗算値、即ち $30 \times 10 = 300$ ビットの容量を有するRAMを備えればよく、復号装置の回路規模を小さくすることができる。さらに、図26の復号装置600では、第1の演算を行う計算部612において、FIFOメモリを有する必要がないので、ロジックの回路規模を小さくすることができる。

一般的に、LDPC符号は符号長が数千から数万と大きいため、Pの値も数百の大きさを持つものが使われる。その場合には、更に本発明に係る復号装置を用いる効果は大きくなる。

また、本発明に係る復号装置は、サムプロダクトアルゴリズムを忠実に実装するものであるため、メッセージの量子化以外の復号損失が起きることはない。

#### 産業上の利用可能性

以上の観点から、本発明に係る復号装置を用いることで、高性能な復号が可能になる。

## 請求の範囲

1. LDPC (Low Density Parity Check) 符号の復号装置であって、

P × P の単位行列、その単位行列のコンポーネントである 1 のうちの 1 個以上が 0 になった行列である準単位行列、前記単位行列もしくは準単位行列をサイクリックシフトした行列であるシフト行列、前記単位行列、準単位行列、もしくはシフト行列のうちの複数の和である和行列、または P × P の 0 行列を構成行列として、前記 LDPC 符号の検査行列が、複数の前記構成行列の組合せで表される場合において、

前記 LDPC 符号の復号のための P 個のチェックノードの演算を同時に行う第 1

10 の演算手段と、

前記 LDPC 符号の復号のための P 個のバリアブルノードの演算を同時に行う第 2 の演算手段と

を備えることを特徴とする復号装置。

2. 請求の範囲第 1 項に記載の復号装置であって、

15 前記第 1 の演算手段は、チェックノードの演算を行う P 個のチェックノード計算器を有し、

前記第 2 の演算手段は、バリアブルノードの演算を行う P 個のバリアブルノード計算器を有する

ことを特徴とする復号装置。

20 3. 請求の範囲第 1 項に記載の復号装置であって、

前記 P 個のチェックノードの演算、または前記 P 個のバリアブルノードの演算の結果得られる P 個の枝に対応するメッセージデータを同時に読み書きするメッセージ記憶手段をさらに備える

ことを特徴とする復号装置。

25 4. 請求の範囲第 3 項に記載の復号装置であって、

前記メッセージ記憶手段は、チェックノードの演算時に読み出される枝に対応するメッセージデータを、検査行列の 1 行方向に詰めるように格納する

ことを特徴とする復号装置。

5. 請求の範囲第3項に記載の復号装置であって、

前記メッセージ記憶手段は、バリアルノード演算時に読み出される枝に対応するメッセージデータを、検査行列の1を列方向に詰めるように格納する

5 ことを特徴とする復号装置。

6. 請求の範囲第3項に記載の復号装置であって、

前記メッセージ記憶手段は、前記検査行列を表す構成行列のうちの、重みが2

以上 の構成行列について、その構成行列を、重みが1の単位行列、準単位行列、

またはシフト行列の和の形で表現したときの、その重みが1の単位行列、準単位

10 行列、またはシフト行列に属するP個の枝に対応するメッセージを、同一のア  
ドレスに格納する

ことを特徴とする復号装置。

7. 請求の範囲第3項に記載の復号装置であって、

前記メッセージ記憶手段は、行数/P個のFIFOと、列数/P個のFIFOとで構

15 成され、

前記行数/P個のFIFOと列数/P個のFIFOは、それぞれ、前記検査行列の行  
と列の重みに対応するワード数を有する

ことを特徴とする復号装置。

8. 請求の範囲第3項に記載の復号装置であって、

20 前記メッセージ記憶手段は、RAM(Random Access Memory)で構成され

前記RAMは、前記メッセージデータを、読み出される順番に詰めて格納し、  
格納位置順に読み出す

ことを特徴とする復号装置。

9. 請求の範囲第1項に記載の復号装置であって、

25 LDPC符号の受信情報を格納するとともに、P個の前記受信情報を同時に読み  
出す受信情報記憶手段をさらに備える

ことを特徴とする復号装置。

10. 請求の範囲第9項に記載の復号装置であって、

前記受信情報記憶手段は、前記受信情報を、前記バリアブルノードの演算に必要となる順番に読み出すことができるよう格納することを特徴とする復号装置。

5 11. 請求の範囲第1項に記載の復号装置であって、

前記P個のチェックノードの演算、または前記P個のバリアブルノードの演算の結果得られるメッセージを並べ替える並べ替え手段をさらに備えることを特徴とする復号装置。

12. 請求の範囲第11項に記載の復号装置であって、

10 前記並べ替え手段は、バレルシフタで構成される  
ことを特徴とする復号装置。

13. 請求の範囲第1項に記載の復号装置であって、

前記第1の演算手段と前記第2の演算手段は、P個の枝に対応するメッセージを求める

15 ことを特徴とする復号装置。

14. 請求の範囲第1項に記載の復号装置であって、

前記第1の演算手段は、前記P個のチェックノードの演算と前記P個のバリアブルノードの演算の一部とを行い、

前記第2の演算手段は、前記P個のバリアブルノードの演算の他の一部を行

20 う

ことを特徴とする復号装置。

15. 請求の範囲第14項に記載の復号装置であって、

前記第1の演算手段は、前記P個のチェックノードの演算と前記P個のバリアブルノードの演算の一部を行うP個の計算器を有し、

25 前記第2の演算手段は、前記P個のバリアブルノードの演算の他の一部を行うP個の計算器を有する

ことを特徴とする復号装置。

16. 請求の範囲第14項に記載の復号装置であって、

前記第1の演算手段が前記P個のチェックノードの演算と前記P個のバリアブルノードの演算の一部を行うことにより得られるP個の枝に対応する第1の復号途中結果を同時に読み書きする第1の復号途中結果記憶手段をさらに備えることを特徴とする復号装置。

5

17. 請求の範囲第16項に記載の復号装置であって、

前記第1の復号途中記憶手段は、前記P個のバリアブルノードの演算の他の一部を行う時に読み出される枝に対応する前記第1の復号途中結果を、検査行列の1を行方向に詰めるように格納する

10 ことを特徴とする復号装置。

18. 請求の範囲第16項に記載の復号装置であって、

前記第1の復号途中結果記憶手段は、2個のシングルポートRAM(Random Access Memory)である

ことを特徴とする復号装置。

15 19. 請求の範囲第18項に記載の復号装置であって、

前記2個のシングルポートRAMは、前記第1の復号途中結果を前記検査行列のP行の枝に対応する前記第1の復号途中結果ずつ交互に格納する  
ことを特徴とする復号装置。

20. 請求の範囲第18項に記載の復号装置であって、

前記2個のシングルポートRAM(Random Access Memory)は、それぞれ同一のアドレスに格納している前記第1の復号途中結果を読み出す  
ことを特徴とする復号装置。

21. 請求の範囲第16項記載の復号装置であって、

前記第1の復号途中結果記憶手段は、前記検査行列を表す構成行列のうちの、  
重みが2以上の構成行列について、その構成行列を、重みが1の単位行列、準単位行列、またはシフト行列の和の形で表現したときの、その重みが1の単位行列、準単位行列、またはシフト行列に属するP個の枝に対応する前記第1の復号途

中結果を、同一のアドレスに格納する

ことを特徴とする復号装置。

22. 請求の範囲第14項に記載の復号装置であって、

前記第2の演算手段が前記P個のバリアブルノードの演算の他的一部を行う

5 ことにより得られるP個の枝に対応する前記第2の復号途中結果を同時に読み書きする第2の復号途中結果記憶手段をさらに備える

ことを特徴とする復号装置。

23. 請求の範囲第14項に記載の復号装置であって、

LDPC符号の受信情報を格納するとともに、P個の前記受信情報を同時に読み

10 出す受信情報記憶手段をさらに備える

ことを特徴とする復号装置。

24. 請求の範囲第23項に記載の復号装置であって、

前記受信情報記憶手段は、前記受信情報を、前記P個のバリアブルノードの演算の他的一部の演算に必要となる順番に読み出すことができるよう格納する

15 ことを特徴とする復号装置。

25. 請求の範囲第14項に記載の復号装置であって、

前記第1の演算手段が前記P個のチェックノードの演算と前記P個のバリアブルノードの演算の一部を行うことにより得られる第1の復号途中結果、または前記第2の演算手段が前記P個のバリアブルノードの演算の他的一部を行うこ

20 とにより得られる第2の復号途中結果を並べ替える並べ替え手段をさらに備えることを特徴とする復号装置。

26. 請求の範囲第25項に記載の復号装置であって、

前記並べ替え手段は、バレルシフタで構成される

ことを特徴とする復号装置。

25 27. 請求の範囲第1項に記載の復号装置であって、

前記第1の演算手段は、前記P個のチェックノードの演算の一部を行い、

前記第2の演算手段は、前記P個のチェックノードの演算の他的一部と、前

記 P 個のバリアブルノードの演算とを行う

ことを特徴とする復号装置。

28. 請求の範囲第 27 項に記載の復号装置であって、

前記第 1 の演算手段は、前記 P 個のチェックノードの演算の一部を行う P 個

5 の計算器を有し、

前記第 2 の演算手段は、前記 P 個のチェックノードの演算の他の一部と、前

記 P 個のバリアブルノードの演算を行う P 個の計算器を有する

ことを特徴とする復号装置。

29. 請求の範囲第 27 項に記載の復号装置であって、

10 前記第 1 の演算手段が前記 P 個のチェックノードの演算の一部を行うことによ

り得られる P 個の枝に対応する第 1 の復号途中結果を同時に読み書きする第

1 の復号途中結果記憶手段をさらに備える

ことを特徴とする復号装置。

30. 請求の範囲第 27 項に記載の復号装置であって、

15 前記第 2 の演算手段が前記 P 個のチェックノードの演算の他の一部と、前記 P

個のバリアブルノードの演算を行うことにより得られる P 個の枝に対応する第

2 の復号途中結果を同時に読み書きする第 2 の復号途中結果記憶手段をさらに備

える

ことを特徴とする復号装置。

20 31. 請求の範囲第 30 項に記載の復号装置であって、

前記第 2 の復号途中結果記憶手段は、前記 P 個のチェックノードの演算の他

の一部と、前記 P 個のバリアブルノードの演算を行う時に読み出される枝に対

応する前記第 2 の復号途中結果を、検査行列の 1 を列方向に詰めるように格納す

る

25 ことを特徴とする復号装置。

32. 請求の範囲第 30 項に記載の復号装置であって、

前記第 2 の復号途中結果記憶手段は、2 個のシングルポート RAM(Random

Access Memory)である

ことを特徴とする復号装置。

3 3 . 請求の範囲第 3 2 項に記載の復号装置であって、

前記 2 個のシングルポート RAM は、前記第 2 の復号途中結果を前記検査行列

5 の P 列の枝に対応する前記第 2 の復号途中結果ずつ交互に格納する

ことを特徴とする復号装置。

3 4 . 請求の範囲第 3 2 項に記載の復号装置であって、

前記 2 個のシングルポート RAM(Random Access Memory)は、それぞれ同一

のアドレスに格納している前記第 2 の復号途中結果を読み出す

10 ことを特徴とする復号装置。

3 5 . 請求の範囲第 3 0 項に記載の復号装置であって、

前記第 2 の復号途中結果記憶手段は、前記検査行列を表す構成行列のうちの、

重みが 2 以上の構成行列について、その構成行列を、重みが 1 の単位行列、準單

位行列、またはシフト行列の和の形で表現したときの、その重みが 1 の単位行列、

15 準単位行列、またはシフト行列に属する P 個の枝に対応する前記第 2 の復号途

中結果を、同一のアドレスに格納する

ことを特徴とする復号装置。

3 6 . 請求の範囲第 2 7 項に記載の復号装置であって、

LDPC 符号の受信情報を格納するとともに、P 個の前記受信情報を同時に読み

20 出す受信情報記憶手段をさらに備える

ことを特徴とする復号装置。

3 7 . 請求の範囲第 3 6 項に記載の復号装置であって、

前記受信情報記憶手段は、前記受信情報を、前記 P 個のチェックノードの演

算の他の一部と、前記 P 個のバリアブルノードの演算に必要となる順番に読み

25 出すことができるよう格納する

ことを特徴とする復号装置。

3 8 . 請求の範囲第 2 7 項に記載の復号装置であって、

前記第1の演算手段が前記P個のチェックノードの演算の一部を行うことにより得られる第1の復号途中結果、または前記第2の演算が前記P個のチェックノードの演算の他の一部と、前記P個のバリアブルノードの演算を行うことにより得られる第2の復号途中結果を並べ替える並べ替え手段をさらに備える

5 ことを特徴とする復号装置。

3 9. 請求の範囲第38項に記載の復号装置であって、

前記並べ替え手段は、バレルシフタで構成される

ことを特徴とする復号装置。

4 0. LDPC(Low Density Parity Check)符号の復号装置の復号方法で  
10 あって、

$P \times P$  の単位行列、その単位行列のコンポーネントである1のうちの1個以上が0になった行列である準単位行列、前記単位行列もしくは準単位行列をサイクリックシフトした行列であるシフト行列、前記単位行列、準単位行列、もしくはシフト行列のうちの複数の和である和行列、または $P \times P$  の0行列を構成行列として、前記LDPC符号の検査行列が、複数の前記構成行列の組合せで表される場合において、

前記LDPC符号の復号のためのP個のチェックノードの演算を同時に行う第1の演算ステップと、

前記LDPC符号の復号のためのP個のバリアブルノードの演算を同時に行う第20 2の演算ステップと  
を含むことを特徴とする復号方法。

4 1. LDPC(Low Density Parity Check)符号の復号をコンピュータに行わせるプログラムであって、

前記LDPC符号の復号のためのP個のチェックノードの演算を同時に行う第25 1の演算ステップと、

前記LDPC符号の復号のためのP個のバリアブルノードの演算を同時に行う第2の演算ステップと

を含むことを特徴とするプログラム。

1/35

図 1



図 2



2/35

図 3



図 4

$$H = \begin{bmatrix} 1 & 1 & 1 & 0 & 0 & 0 & 1 & 0 & 1 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 & 1 & 0 & 0 & 0 & 0 & 0 & 1 & 1 \\ 0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1 & 1 & 1 & 0 & 1 & 1 & 0 & 0 & 1 \\ 1 & 1 & 0 & 0 & 0 & 1 & 0 & 1 & 0 & 1 & 1 & 0 \\ 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 & 1 & 0 & 1 & 1 \end{bmatrix}$$

図 5



4/35

図 6



図 7



図8



図9



7 / 35

一  
六



8/35

図11



9/35

図12A



図12B



図12C



12 / 35

13  




図14



5  
—  
四

15/35

図16A



16/35

図16B



16C  
四



図17



8  
—  
四



図19



図20



図21



図22



図23



25/35

図24



図25



27/35

図26



図27



図28



30 / 35

図29



31 / 35

図30



32/35

図31



33/35

図32



図33



図34



## INTERNATIONAL SEARCH REPORT

International application No.

PCT/JP2004/005562

A. CLASSIFICATION OF SUBJECT MATTER  
Int.Cl<sup>7</sup> H03M13/09, 13/19

According to International Patent Classification (IPC) or to both national classification and IPC

## B. FIELDS SEARCHED

Minimum documentation searched (classification system followed by classification symbols)  
Int.Cl<sup>7</sup> H03M13/00-13/53Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched  
Jitsuyo Shinan Koho 1922-1996 Jitsuyo Shinan Toroku Koho 1996-2004  
Kokai Jitsuyo Shinan Koho 1971-2004 Toroku Jitsuyo Shinan Koho 1994-2004Electronic data base consulted during the international search (name of data base and, where practicable, search terms used)  
IEEE Xplore (LDPC, Decode, Architecture), IEICE Web (LDPC,  
TEIMITSUDOPARTY, TEIMITSUDOAYAMARI, FUKUGOU) (in English and in Japanese)

## C. DOCUMENTS CONSIDERED TO BE RELEVANT

| Category* | Citation of document, with indication, where appropriate, of the relevant passages                                                                                                      | Relevant to claim No. |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| P, A      | JP 2003-269302 A (Fujitsu Ltd.),<br>17 October, 2003 (17.10.03),<br>Full text; all drawings<br>(Family: none)                                                                           | 1-41                  |
| A         | JP 2002-33670 A (Agere Systems Guardian Corp.),<br>31 January, 2002 (31.01.02),<br>Full text; all drawings<br>& EP 1158682 A2 & US 6539367 B                                            | 1-41                  |
| A         | S. Kim et al., 'Parallel VLSI Architectures for<br>a Class of LDPC Codes', IEEE International<br>Symposium on Circuits and Systems, 2002, ISCAS<br>2002, Vol.2, No.2002, pages 26 to 29 | 1-41                  |

 Further documents are listed in the continuation of Box C. See patent family annex.

|                                          |                                                                                                                                                                                                                                              |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| * Special categories of cited documents: |                                                                                                                                                                                                                                              |
| "A"                                      | document defining the general state of the art which is not considered to be of particular relevance                                                                                                                                         |
| "E"                                      | earlier application or patent but published on or after the international filing date                                                                                                                                                        |
| "L"                                      | document which may throw doubts on priority claim(s) or which is cited to establish the publication date of another citation or other special reason (as specified)                                                                          |
| "O"                                      | document referring to an oral disclosure, use, exhibition or other means                                                                                                                                                                     |
| "P"                                      | document published prior to the international filing date but later than the priority date claimed                                                                                                                                           |
| "T"                                      | later document published after the international filing date or priority date and not in conflict with the application but cited to understand the principle or theory underlying the invention                                              |
| "X"                                      | document of particular relevance; the claimed invention cannot be considered novel or cannot be considered to involve an inventive step when the document is taken alone                                                                     |
| "Y"                                      | document of particular relevance; the claimed invention cannot be considered to involve an inventive step when the document is combined with one or more other such documents, such combination being obvious to a person skilled in the art |
| "&"                                      | document member of the same patent family                                                                                                                                                                                                    |

Date of the actual completion of the international search  
12 July, 2004 (12.07.04)Date of mailing of the international search report  
27 July, 2004 (27.07.04)Name and mailing address of the ISA/  
Japanese Patent Office

Authorized officer

Facsimile No.

Telephone No.

## A. 発明の属する分野の分類(国際特許分類(IPC))

Int. C17 H03M13/09, 13/19

## B. 調査を行った分野

## 調査を行った最小限資料(国際特許分類(IPC))

Int. C17 H03M13/00-13/53

## 最小限資料以外の資料で調査を行った分野に含まれるもの

|             |            |
|-------------|------------|
| 日本国実用新案公報   | 1922-1996年 |
| 日本国公開実用新案公報 | 1971-2004年 |
| 日本国実用新案登録公報 | 1996-2004年 |
| 日本国登録実用新案公報 | 1994-2004年 |

## 国際調査で使用した電子データベース(データベースの名称、調査に使用した用語)

IEEE Xplore (LDPC, Decode, Architecture)  
 IEICE Web (LDPC, 低密度パリティ, 低密度誤り, 復号)

## C. 関連すると認められる文献

| 引用文献の<br>カテゴリー* | 引用文献名 及び一部の箇所が関連するときは、その関連する箇所の表示                                                                                                                                               | 関連する<br>請求の範囲の番号 |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| PA              | JP 2003-269302 A (富士通株式会社) 2003.<br>10. 17, 全文, 全図 (ファミリーなし)                                                                                                                    | 1-41             |
| A               | JP 2002-33670 A (アギア システムズ ガーディアン コーポレーション) 2002. 01. 31, 全文, 全図<br>& EP 1158682 A2 & US 6539367 B                                                                              | 1-41             |
| A               | S. Kim et al, 'Parallel VLSI Architectures for a Class of LDPC Codes', IEEE International Symposium on Circuits and Systems, 2002, ISCAS 2002, Volume 2, November 2002, p.26-29 | 1-41             |

 C欄の続きにも文献が列挙されている。 パテントファミリーに関する別紙を参照。

## \* 引用文献のカテゴリー

- 「A」特に関連のある文献ではなく、一般的技術水準を示すもの
- 「E」国際出願日前の出願または特許であるが、国際出願日以後に公表されたもの
- 「L」優先権主張に疑義を提起する文献又は他の文献の発行日若しくは他の特別な理由を確立するために引用する文献(理由を付す)
- 「O」口頭による開示、使用、展示等に言及する文献
- 「P」国際出願日前で、かつ優先権の主張の基礎となる出願

## の日の後に公表された文献

- 「T」国際出願日又は優先日後に公表された文献であって出願と矛盾するものではなく、発明の原理又は理論の理解のために引用するもの
- 「X」特に関連のある文献であって、当該文献のみで発明の新規性又は進歩性がないと考えられるもの
- 「Y」特に関連のある文献であって、当該文献と他の1以上の文献との、当業者にとって自明である組合せによって進歩性がないと考えられるもの
- 「&」同一パテントファミリー文献

## 国際調査を完了した日

12. 07. 2004

## 国際調査報告の発送日

27.7.2004

## 国際調査機関の名称及びあて先

日本国特許庁 (ISA/JP)

郵便番号 100-8915

東京都千代田区霞が関三丁目4番3号

特許庁審査官(権限のある職員)

田中 広介

5K 8529

電話番号 03-3581-1101 内線 3555